안녕하세요.
 
이번에는 프로그램관 관련된 용어에 대하여 한번 개념 정리를 해볼까 합니다.
 
작년에 신입사원이 들어오고나서 교육하느라 이리저리 하다보니 나름 노하우가 생긴거 같아서
공유해보면 좋을 거 같네요.
 
가장 기본부터...
프로그램이 뭔지 물어보면 막상 다들 대답을 못합니다.
저의 면접에 빠지지 않는 질문이기도 하고요.
 
1. 프로그램 이란
  - 여기서는  computer programming 을 말합니다. 
     뭐 면접장에서 나올 것 같은 질문인데 아마 회사보다는 공대 면접장에서 교수들이 할 질문 같이 보이는 군요,
    위키에서 보면 아래와 같이 정의하고 있습니다.
 
        컴퓨터 프로그래밍(영어computer programming) 또는 간단히 프로그래밍(programming문화어: 
        프로그램 작성) 혹은 코딩(coding)은 하나 이상의 관련된 추상 알고리즘을 특정한 프로그래밍 언어를 
      이용해 구체적인 컴퓨터 프로그램으로 구현하는 기술을 말한다. 
 
  그럼 이제는 프로그램이 무언지 알기 위하여 "알고리즘" 이 무언지 "프로그래밍 언어" 가 무언지 알아야 겠군요,
 
2. 알고리즘 이란
  - 역시 위키에서 보면
    알고리즘(라틴어독일어: Algorithmus, 영어algorithm 알고리듬[*]IPA[ǽlɡərìðm])은 수학과 컴퓨터 과학
   언어학 또는 관련 분야에서 어떠한 문제를 해결하기 위해 정해진 일련의 절차나 방법을 공식화한 
    형태로 표현한 것을 말한다.
  - 다시 말하면 "문제 해결을 위한 절차,방법을 공식화한 형태로 표현한 것" 이군요.
 
3. 프로그래밍 언어 란?
  - 위키 위키 위키~~~
   프로그래밍 언어는 컴퓨터 시스템을 구동시키는 소프트웨어를 작성하기 위한 형식언어이다. 
   고급 언어일수록 사람이 사용하는 언어에 가깝다.
  - 정리하면 "컴퓨터를 동작시키는 소프트웨어"
 
4. 따라서 프로그램이란
  - 어떤 문제 해결을 위하여 절차,방법을 공식화한 형태를 컴퓨터를 동작시키는 소프트웨어로 구현하는 기술
  - 로 정의할 수 있겠네요.
 - 더 쉬운말로 
    1) 해결하여야 할 문제가 있고
    2) 이를 해결할 공식화된 원칙을 설계하고
    3) 설계된 것을 프로그래밍 언어를 사용하여 구현하여 ,
    4) 문제를 해결하는 방법 또는 기술
 
5. 계속 고찰해보면 
  1) 문제 발생 -> 무언거 해결해야할 문제가 있다는 거지요. 문제가 없다면 해결할 이유도 없음.
  2) 원칙을 설계 
    -> 근데 이게 무언가 규칙성을 찾아서 단순하게 바꾸어야 된다는 겁니다.
    -> 이게 설계인데 이 힘은 공학(물리,화학) 또는 수학을 통하여 길러지는 힘입니다.
    -> 수학이 바로 복잡한 자연현상 등을 숫자를 이용하여 한줄의 수식으로 설명하는 
        놀라운 알고리즘의 변환 과정을 경험하고 배울 수 있습니다.
    -> 수학 못하면 2) 번을 못하고 3)번만 할 줄 알게 됩니다. 주로 코더라고 부르죠.
  3) 프로그램 언어를 사용하여 구현
    -> 수학에서는 숫자를 이용하여 알고리즘을 표현하고
    -> 프로그래밍에서는 프로그램 언어를 사용합니다.
    -> 언어라는 것은 영어를 보면 알듯이 일단 단어암기 및 문장구조 규칙을 배워야 되죠.
    -> 신기한 것은 같은 단어와 문법구조를 가지고 사람을 마음을 감동시키는 대작을 쓰듯이,
        프로그램도 구현하는 사람에 따라 노벨문학상 못지 않은 대작을 구현하시는 분들도 있다는 겁니다.
   -> 저희 같은 범인들은 그냥 대가의 코드를 보면 눈물한번 찔끔하고 열심히 ctrl-c ,v!
 4) 이렇게 해서 문제를 해결해야죠.
 
6. 이게 "프로그래밍"입니다.
 
 이제 여러분들이 어떤 작업을 하고 계시는 지 내가 어디에 위치해 있는지 명확히 깨달으셨으면 합니다.
 
 어느 분야에서건 "용어 정의" 및 "용어 이해" 가 중요합니다.
 다음번엔 CPU,메모리,캐쉬 등으로 차례로 한번 용어에 대하여 적절한 예를 들어가면 설명해보겠습니다.
 
 지루한 내용일 수도 있는데 읽어주셔서 감사드립니다~~

안녕하세요.

임베디드 개발을 하게되면 여러가지 알수없는 현상을 목격하고 이를 해결하기 위한 노력을 하게 됩니다.

운이 좋아서 쉽게 원인을 해결할 때도 아니면 소 뒷발에 쥐잡기로 해결이 되는 경우가 있지요.

오늘 몇가지 사례를 공유해보고자 합니다.

거창한 분석방법을 이용해서 해결한 것이 아니고 자유게시판인 만큼 그냥 지나가는 소리로 읽어주시면 감사하겠습니다.

제가 경험했던 경우와 주변 엔지니어에게 들은 신기한 케이스들입니다. 너무 많지만 몇가지만 공유해보겠습니다.

1. 대학 석사때 아는 형님

- 하드웨어 보드르 만들었는데 한달째 디버깅도 안되고 동작이 안됨.

- 매일 끙끙 앓다가 꿈에서 20번 버스가 사람을 태우고 자기 앞을 지나감.

- PCB 에 20번 BUS 라인을 확인하고 바로 해결 (단선)

- 이해가 되시나요? 그 버스가 그 bus 이더냐?

2. 제가 초보때

- NAND 칩이 바뀌었는데 동작이 안됨.

- 삼성 NAND 스펙만 정말 한달 내내 정독 정독. 코드도 4페이지 이하라 한달내내 그것만 봄.

- OOB 영역 크기가 바뀐 문제였는데 해결이 안됨.

- 한달째 되는 새벽녘 잠자리에서 어슴푸레 꿈과 현실이 구분 안되는 상황에서

누워있는 천장에서 왼쪽엔 코드가 오른쪽에 데이터시트가 나타남.

- 신기한 것은 어슴푸레가 아니라 코드 한자 한자 테이터 시트 한자한자 다 읽어짐.

- 심지어 페이지 넘김 해도 선명하게 모든 글자가 다 읽힘 (아마 자동으로 다 외어 졌던듯)

- 꿈속에서 데이터 시트를 다시보다가 특정 문구 발견

- 해당 코드로 진입하여 머리속으로 수정 및 디버깅. 머리속으로 컴파일 단축키도 눌렀음.

- 꿈속에서 이건 해결한 거다 라고 확신이 듬.

- 출근하여 정말 그 부분(당연히 꿈 속의 코드랑 현실 코드랑 같지요) 한 줄만 수정하여 해결

3. 초보때 선배 엔지니어 술자리에서 제가 졸라서 들은 신기한 경험 (제발 이야기해주세요~~ 이런 분위기)

- 커피 자판기 제작 회사임

- 계속 현장에서 자판기 컵이 걸린다는 신고

- 사무실에서는 재현 불가

- 자주 목격되는 현장 출장 방문

- 며칠을 반복하며 생길때 까지 방문

- 일주일뒤 정말 컵이 많은데 걸려서 나오지 않음.

- 떨리는 마음으로 커피 자판기 도어를 염.

- 너무 놀래서 뒤로 자빠질 뻔 함.

- 컵이 쌓여서 마지막 1-2개정도만 남았는데 그 컵이 컵트레이 속에서 공중에 떠 있음. 게다가 살짝 움직이면서 둥둥.

- 그래서 그 트레이를 손으로 가만히 잡으니 우주선 착륙하는 것 마냥 천천히 착륙함.

- 회사로 돌아가서 트레이 사출 재질을 변경함.

- 다들 이유를 아시겠죠? ㅎㅎㅎ

4. 기구 엔지니어 썰

- 표 판매기 기구에서 500원 동전이 자꾸 걸림.

- 알바 3명을 시켜서 500원 잔뜩 주고 재현될때까지 시킴.

- 일주일 뒤...

- 알바 한 명이 동전이 걸렸다고 달려옴.

- 긴장된 표정으로 엔지니어 총 출동 (야! 절대 손대지 말고 가민하 놔둬 를 외치며 30m 거리를 날라감)

- 도어를 정말 천천히 열어봄. 재현상황이 무너질까봐~~

- 매끈한 동전 회수함 앞단에서 평면판 위에 500원 짜리 동전이 세로로 서 있었음.

-> 500원 짜리 동전을 랜덤하게 던져서 똑바로 설 확율임.

-> 8시간 x 5일 x 3명 당 1번

- 바닥을 평면으로 하지 않고 기울어지게 설계 변경

 

다들 그런거 있쟎아요 나만 아는 신기한 경험들 ㅎㅎ

 

즐거운 하루 되세요~~~

안녕하세요.
 
더 바빠지기 전에 생각나는 부분을 한번 대략 정리해야 될거 같아서 글을 올립니다.
 
보통 프로그램을 잘 짜려면 문법을 알아야 하고
코딩을 잘해야 하고 그러는데 코딩을 잘한다는게 어떤건지 명확히 모를때가 많습니다.
-> 원래는 "공학적으로 사고하는 법" 이 글을 적는다고 하다가 엉뚱한 데로 빠져서 제목을 바꿉니다.
 
그냥 저의 과거를 돌아보면 이랬던 것 같습니다.
 
초보때는 미션이 주어지면 아래 순서로 작업하였습니다.
0. 뭘 해보라고 듣고 온다.
1. 에디터 창을 연다.
2. 무언가 생각나는 데로 코드를 써본다.
3. 뭔가 계속 꼬이고 생각이 안난다.
4. 문법을 몰라 인터넷 뒤져 본다.
5. 어디서 소스 주워서 복붙했는데 컴파일 오류가 나거나 잘 안된다.
6. 투덜거리며 다시 다른 소스 주워온다.
7. 몇번 하다가 안되면 다 지우고 내가 짜고 말지 하며 다시 혼자 짜기 시작한다.
8. 컴파일 오류로 한참 헤멘다.
9. 어찌 컴파일은 되었는데 출력은 원하는 결과가 아니다.
10. 중간마다 디버그 걸어서 어디서 문제인지 확인한다. (뒤부터 앞으로)
11. 당연히 맞다고 생각되었던 부분이 이상하게 오류였다. 스스로 꿀밤한번때리고
12. 이게 돌아깔까 하는 불안감과 누더기 소스를 물어볼데도 없이 혼자 릴리즈한다.
13. 신기하게도 현장에 돌아가는데 며칠 또는 몇달 뒤 큰 사고와 함께 1,번 부터 반복한다.
 
20년이 지나고는 이렇게 바뀌었습니다.
1. 한국말로 미션이 주어진다.
2. 짧은 한국말을 조건이 달린 긴 한국말로 바꾸어 되물어본다.
   - 이러이러해서 이런 조건에 이런 출력이 나오는 기능 말인가요?
3. 처음 미션이 바뀐다. 요청자도 자신의 요구사항을 정확히 모르는 상황이 발생함.
4. 1-2 과정을 반복해서 간단한 요구사항 문서를 만든다.
  - 컨펌하러 보내놓고 설계시작
5. 알고리즘을 말로 풀어서 종이에 써본다.
  - 조건 별로 나누어 본다.
6. UML 미스무리하게 나름데로 다이어그램 그려서 설계해본다.
7. 코딩 시작
9. 종이보고 코딩 , 종이보고 코딩, 한번 쓴 코드는 왠만해서는 다시 지울 필요가 없다.
11. 그동안 짜놓은 라이브러리가 많아서 그냥 복붙이다.
   - CTRL-c,v 만 반복하고 있는 내가 한심해지기 시작한다.
10. 필요함 함수가 생겨서 github 뒤져본다.
11. 제일 많이 사용되는 라이브러리 갖와서 복붙
  - 라이브러리 복사 전 별도 샘플 검증 테스트 (테스트 로직 작성)
12. 완성된 함수를 이용한 테스트 로직 작성하여 검증.
  - 입출력 데이터가 많다면 엑셀이든 db 든 데이터로 정리.
13. 검증된 함수 부분을 메인 함수에 복붙
14. 머신에 다운후 최종 테스트
15. 현장 릴리즈 후 아무 이상 없음에 약간 불안해 하며 무소식이 희소식이라고 생각하고 다음 미션을 한다.
16. 정말 전화 한통없다. 그래도 불안하다.
 
그냥 한번 생각나는데로 적어보았습니다.
ㅎㅎ
 
즐거운 주말 되세요~~
저는 다음주에 빠듯한 해외 출장으로 몸과 정신을 혹사하러 잠시 다녀오겠습니다. T.T

+ Recent posts