Friday, October 26, 2018

Interview me

이건 성공하는 프로그래밍 공부법 책에 챕터가 끝날 때 마다 개발자 들의 인터뷰 내용이 있는데, 거기에 있는 인터뷰 질문에 대해 내가 답변한 걸 적어본 것이다.

Q. 간단한 자기 소개 부탁드려요


저는 버넥트에서 AR/VR 기술을 사용하여 제품 개발을 하는 일을 하고 있는 김종필이라고 합니다. 회사에서의 소개는 이렇고 좀 더 폭넓게 소개해 드리면 소프트웨어를 개발하는 걸 업으로 삼고 배우고 익히는 걸 멈추지 않으려 노력 및 실천을 하고 있는 한 프로그래머라고 보면 좋을 것 같네요. 또 제가 중요하다고 생각하는 소프트웨어의 가치를 전파하기 위해 여러 대학생 및 이제 프로그래밍 일을 한지 얼마 안된 친구들과 소통하고 문제를 같이 고민하고 해결해 나가는 일도 같이 하고 있습니다.

Q. 요즘 리얼리티 프로그램이 대세잖아요. 하루 일과를 그냥 가감없이 보여줌으로써 시청자도 같은 감성을 공유하거나 삶을 간접적으로 체험한다거나. 이런 관점에서 하루 일과를 공유해주신다면?


출근은 유연 근무제를 하고 있어서 08:30 ~ 10:30 사이에 출근한 후에 17:30 ~ 19:30 에 퇴근하면 되는 환경입니다. 저는 일찍 출근하고 일찍 퇴근하는 걸 좋아하기에 08:30에 출근합니다. 사실은 아내가 대학원에서 공부를 하고 있기에 집에 일찍 가서 이제 두살 된 딸도 봐야 하는 이유가 더 큽니다. 출근 하기 전에 항상 오늘은 무슨 일을 하고 일을 언제까지 얼마나 해야 하는지 생각합니다. 회사 출근해서 자리에 앉은 다음에 이것 저것 상황 파악하고 하는 것 보다 미리 생각하고 나서 나만의 페이스 대로 일하는 걸 좋아합니다. 현재는 공기업의 연구과제 및 대기업 PoC 과제, 자체 라이브러리 개발 등 여러 가지 일을 하고 있습니다. 기술 베이스가 AR이다 보니 다양한 플랫폼과 다양한 디바이스를 가지고 개발을 하고 있는데요. 태블릿, 스마트폰, 스마트 글라스 등 디바이스의 특성도 있지만, android, iOS 등 플랫폼의 특성도 있기에 이런 환경에서 개발하는 것에 익숙해 져야 하는 것도 있습니다. 주로 하는 업무는 개발이 많고 연구과제 및 테스트도 많이 합니다. 기획팀과 디자인팀과도 협업해야 하기에 종종 회의도 하고, 디자인 시안, 이미지, 문서 등등 많은 걸 공유하며 같은 목표를 달성하기 위해 각 팀이 각자 맡은 바 일을 열심히 합니다.

Q. 프로그래밍 공부를 시작하게 만든 강력한 동기가 무엇이었나요?


PC 게임이었던 것 같습니다. 초등학교 때 컴퓨터 학원에 다니면서 컴퓨터 쓰는 법과 프로그램 짜는 법, PC 게임 하는 것 등, 컴퓨터를 학원에 다니면서 자연스럽게 컴퓨터라는 걸 접했습니다. 중학교 입학 할 때 부모님이 처음 PC를 사주셨는데 그걸로 열심히 게임을 했고 게임을 하다 보니 어떻게 만들어야 하는지 PC 잡지 등을 통해 알아보다가 프로그램 언어를 배워서 프로그램이라는 걸 짜서 실행 파일을 만들면 게임을 할 수 있다는 걸 알게 됐죠. 신기한건 그 때 부터 지금까지 게임을 만들어 본 적 없이 프로그래머의 인생을 살고 있긴 한데, 프로그래머가 되어야 되겠다는 동기는 확실히 PC 게임을 해보고 만들어 봐야 겠다는 생각을 하면서 부터가 맞는 것 같습니다.

Q. 맨 처음 누구나 프로그래밍 공부는 막막할 것 같습니다. 혼란스러웠던 시기의 에피소드를 얘기해주실 수 있는지요?


사실 컴퓨터 학원에서 프로그래밍을 배우긴 했는데 공부를 했다기 보다는 기계적으로 프로그램 짜는 훈련을 했던 것 같습니다. For문 돌려서 별찍기, 국어, 수학, 영어 점수 입력받아서 총점, 평균 구하기, 간단한 수학 문제 및 함수 만들어서 계산하기, 특정 년도와 월의 달력 출력하기 등 제 생각대로 프로그래밍을 했다기 보다는 컴퓨터 학원에서 정해준 문제를 푸는 방법을 익히고 그걸 그대로 프로그램을 짜는 훈련을 열심히 했던 거죠. 10살 부터 했는데 어린 나이에 뭔가 깊이 있게 공부를 했다기 보다는 자연스럽게 컴퓨터 프로그램이라는 형태가 어떤 것이라는 걸 반복 훈련을 통해 알게 되고 습관이 되다 보니 이후에 프로그래밍 하는 것도 아주 막 어렵거나 하진 않았던 것 같습니다. 그러니까 남들과 달리 어린 나이에 프로그래밍을 접한 거라 막막함을 느끼거나 생각할 시간도 없었다고 보는게 맞겠네요.
그래도 질문이 혼란스러웠던 시기니까 그 시기를 얘기해 보면 대학 다니면서 컴퓨터에 관련된 공부할 때였던 것 같습니다. 프로그래밍의 기본 적인 건 이미 알고 있었지만 뭔가 언어적인 특징을 조금 더 공부한다던가, UI 관련 프로그래밍을 할 때라던가 할 때 계속 공부해 나가면서 알아가야 했죠. 누구나 다 어려워 했던 C언어의 포인터의 개념도 공부해서 알았다고 하더라도 제대로 이해해서 활용하기 까지 저 역시 남들과 같이 오랜 시간이 걸렸던 것 같습니다. 또 컴퓨터를 배운다는게 프로그래밍을 배우는게 다 인줄 알았던 저에게 대학에서 공부했던 과정은 저를 더 컴퓨터에 대해 알게 해줬기 때문에 코딩을 잘 하냐 못하냐의 갈등 속에서도 소프트웨어를 만든다는 것에 대한 체계를 잡아 나갈 수 있었던 것 같네요.

Q. 자신만의 프로그래밍 공부법이 있으셨을 것 같습니다. 초창기, 성장기, 그리고 현재 왕성하게 활동하고 있느니 기간, 이 세 기간으로 나누어서 소개해주실 수 있나요?


초창기

대학 다닐 때는 프로그래밍 공부를 계속 해봐야 실력이 는다고 생각해서 방학때 스터디 모임도 하고, 게임 프로그래밍 학원도 다니고 했던 것 같습니다. 또 전공 관련된 책 역시 용돈으로 사서 원서 번역본 할 것 없이 이것 저것 많이 읽고 친구들한테도 빌려주고 했었습니다. 프로그래밍 관련된 지식이라면 모르는게 없어야 한다고 생각해서 계속해서 공부하고 많은 책을 읽어 봤던 것 같네요.

성장기

제가 성장했던 시기는 현업에서 일하고도 한참 지난 후 였다고 생각합니다. 프로그래머가 성장하기 위해서는 많은 경험이 필수적인데 저는 몇 년 동안 많은 경험을 하고도 크게 성장하지 않았다고 생각했었습니다. 그 중에 큰 걸림돌은 한가지 플랫폼과 한가지 언어에 종속적인 일을 쭉 해오다 보니 그랬던 것 같고, 제가 크게 성장할 수 있었던 계기는 기존에 해 왔던 PC용 프로그램이나 앱 개발이 아닌 웹 프로그래밍을 접하면서 부터였습니다. 그리고 그 웹 프로그래밍 경험도 쌓이다 보니까 어느 한가지 결론에 다다르게 되었는데요. 사실 여러 선배 개발자 분들도 아실거라 생각되는데 어떤 시스템과 서비스를 만드는 일에 특정 프로그래밍 언어와 플랫폼이 종속적이어야 하는 이유를 찾을 수 있는지를 생각해 보면 프로그래밍 외에도 알아야 할게 많다는 걸 느끼면서 성장을 했던 것 같네요.

현재

지금은 현업에서 아직도 프로그래밍이 가능할까 싶을 정도의 경력이 쌓여 있는데, 경력이 쌓이고 경험이 많아질수록 점점 더 기본에 충실해야 하고 원리에 대한 깊은 이해가 필요하다는 걸 많이 느끼고 공부하는 걸 멈추고 있지 않습니다. 알고리즘 문제 풀이를 하면서 논리적인 사고를 해야 한다는 걸 계속 느끼고 있고, 여러 플랫폼이 가지는 장점과 철학을 리뷰하면서 왜 이런 라이브러리와 프레임워크가 생기게 되었을까에 대해 만든 사람의 입장에서 이해해 보려고 많은 문서와 책을 읽고 있습니다. 이제는 저의 이런 경험을 후배 프로그래머에게 나눠주고 싶은 마음에 멘토링 활동도 열심히 하고 있습니다.

Q. 프로그래밍 공부에서 알고리즘이나 수학이 중요하다고 하는데요. 꼭 그런가요?


분야가 워낙 다양하다 보니 "그럴 수도 있고 아닐 수도 있다"로 해석될 수도 있지만, 저는 수학이 중요하다고 생각하는 쪽입니다. 웹 응용쪽 개발을 하는 프로그래머는 수학을 몰라도 아름다운 UI와 비지니스 로직 처리를 구현해 낼 수 있죠. 하지만 영상 인식의 분야와 머신 러닝 기반으로 개발을 하는 프로그래머는 관련된 수학 모델 설계와 지식이 필요할 수 있습니다. 그런데 이것도 수학적 지식에서 보면 그런 것일 수 있지만 프로그래밍을 하는 데는 "수학적 지식" 보다는 "수학적 사고 방식 및 논리 전개"가 중요한 것 같습니다. 수학적 지식은 필요할 때 다시 공부해서 적용하면 되지만 사고 방식 및 논리 전개는 자연의 법칙에 대한 이해와 깊은 사고 능력을 훈련하지 않고서는 배울 수 없는 가치이기 때문이죠. 수학을 배운다는 건 지식을 배우는 것도 있지만 사고 능력을 배운다는 차원에서 중요하다고 봅니다.

Q. 프로그래밍에서 중요한 것 세 가지만 꼽는다면 무엇이 있을까요? 세 가지 넘어도 됩니다.


소프트웨어에 대한 본질적인 이해

컴퓨터라는 물건이 어떻게 동작하고 이걸 통해서 뭘 하고 싶어하는 건지 그 근본적인 이해가 반드시 필요한 것 같습니다. 무슨 일이든 기초가 튼튼해야 응용력도 쉽게 길러지는 법이라고 생각합니다. 여기서 컴퓨터에 대한 이해가 하드웨어 지식도 필요하지만 소프트웨어에 대한 지식이 반드시 필요합니다. 프로그래밍이라는 걸 하기 전에 소프트웨어에 대한 이해를 하고 프로그래밍을 하는걸 강력하게 추천합니다.

코드 리뷰

흔히 컴퓨터는 거짓말을 하지 않고 프로그램이 잘못된 건 전적으로 프로그래머의 잘못이라고 하죠. 그런데도 많은 프로그래머들은 컴퓨터가 잘못된 것, 나는 프로그램을 제대로 짰을 것이라는 착각을 합니다. 프로그램을 잘 짜려면 여러가지 요소가 필요한데, 저는 무엇보다도 자기가 가지고 있는 생각의 흐름대로 프로그램을 짰는지 리뷰를 하는게 중요하다고 생각합니다. 코드를 타이핑 할 때는 몰랐던 많은 논리적 오류는 물론이고, 새로운 자신을 발견하고 반성도 하며 더 나은 내가 되는 좋은 계기가 되거든요. 이 훈련이 잘 되어 있으면 꼭 컴파일이나 빌드 작업을 해봐야 검증이 될 거라는 미신을 떨쳐내고 코드 리뷰만으로도 얼마든지 좋은 프로그램을 짤 수 있는 경험을 할 수 있게 됩니다.

장인 정신

프로그래밍을 공부하는 거의 대부분의 프로그래머는 코드를 짜고 동작하게 만드는 것 만이 프로그래머의 역할이라고 생각할 수도 있지만, 범위를 넓혀서 큰 프로그램을 짜고 여럿이 함께 훌륭한 소프트웨어를 만들어 나가는 과정은 동작하는 코드를 짜는 것 만이 전부가 아닙니다. 이 소프트웨어를 쓰는 사람의 요구, 현실 세계에서 요구되는 것들을 해결해야 하는 문제에 대한 분석, 이걸 이해해서 소프트웨어로 옮겨 나가는 논리적인 과정, 실제 가치가 있는 서비스인지 검증하는 절차, 지속적으로 서비스가 가능하고 필요한 추가 요구를 반영해서 더 좋은 소프트웨어를 만들어가는 방법. 이걸 소프트웨어 공학이라고 합니다. 이 분야는 경험적으로도 증명이 되었고 역사적으로도 많은 프로그래머 선배들이 좋은 책을 써 와서 간접적으로도 알 수 있는 지식입니다. 소프트웨어 요구사항의 정확한 분석, 설계, 개발, 테스팅, 유지보수등 소프트웨어를 만드는 일련의 과정을 거친다면 소프트웨어를 쓰려는 사람들이 품질 좋은 서비스와 생산활동을 할 수 있게 됩니다. 프로그래밍 하는 방법 외에도 소프트웨어 엔지니어링 공부가 꼭 필요하고, 소프트웨어의 품질을 높이는 것에 조금 더 신경을 쓰게 되겠죠.

Q. 닯고 싶은 프로그래머가 있나요? 동료도 좋고 유명한 프로그래머도 좋습니다. 그리고 그 이유는?


Robert C Martin 입니다. 소프트웨어에 대한 중요한 철학이 무엇인지를 잘 알고 그걸 알려주신 분이죠. SOLID 원칙, clean coder, 장인 정신 등 프로그래밍 실력이 뛰어나야 함은 물론 그 단계를 넘어 소프트웨어를 바라보는 시선이 어떠해야 한다는 얘기를 명확하게 해 줘서 좋은 것 같습니다. 어느 정도 프로그래밍 스킬은 익힌 것 같은데 소프트웨어를 뭔가 잘 만들어야 겠다는 욕구가 생기기 시작할 때 쯤에 이분의 명서들을 읽어 보면 많은 도움이 되고 많은 가치를 배울 수 있을 겁니다.


Q. 처음 프로그램다운 프로그램을 만든 경험담이 있으신지요? 어떤 프로그램이었나요? 그리고 지금 생각해보면 그 프로그램은 프로그래머 인생에서 어떤 역할을 했다고 생각하나요?


첫 회사에 입사해서 아직 뭐가 뭔지 모르던 시절에 회사 솔루션의 한 부분의 기능을 맡아서 구현하게 되었습니다. FTP 파일과 로컬 파일의 차이점을 비교하고 파일 동기화 기능 등을 구현하는 UI와 파일 diff, FTP 파일 전송 등등의 기능을 구현했죠. 지금은 뭣 모르던 신입때 처럼 우와좌왕 하면서 프로그래밍을 하진 않겠지만, 그 때는 많은 버그와 새로운 기능을 추가하면서 생기는 문제들을 해결하는데 많은 시간을 쏟을 때였습니다. 그리고 그 기능이 담긴 솔루션을 어느 공공기관에 납품을 하게 되었고, 거기서 실제 사용자들이 사용하면서 추가된 또 수많은 버그들과 요구사항 추가 구현 등을 하면서 정말 많은 경험을 했던 기억이 나네요. 짧은 기간에 프로그래밍을 잘했냐 못했냐 보다는, 사용자가 쓸 수 있는 프로그램을 제대로 만드는 능력은 코딩 실력과는 다른 것이라는 값진 경험과 깨달음을 얻었습니다. 대학에서 공부했던 소프트웨어 공학을 실전에서 신입때 경험해 보고 나니 이후에 만들었던 모든 프로그램들은 그냥 기능만 동작하게 만들었던 것 같지 않았습니다. 주어진 기능 구현만이 프로그래머가 해야 할 일이 다가 아니라는 걸 알았던 때였던 것 같네요.

Q. 프로그래머라서 행복할 때는 그리고 불행하다고 생각할 때는?


행복할 때는 쓸모 있는 소프트웨어를 세상에 내 놓았을 때인것 같습니다. 가장 훌륭한 소프트웨어는 처리 속도가 빠르고 기능이 많은 프로그램이 아니라, 사람들이 계속해서 쓰고 지속적인 업데이트를 통해 완벽에 가까운 프로그램을 만들어 나갈 때인 것 같습니다. 그런 소프트웨어를 계속해서 개발하고 사용하는 사람들의 가치를 소프트웨어를 통해 구현해 나갈때가 누구나 행복해 하는 때가 아닐까요?
불행할 때는 근무 시간의 불확실성인 것 같습니다. 단순히 야근이 많아서 일이 힘들다도 포함될 수 있지만, 일의 특성상 근무 장소나 시간의 제약이 거의 없다 보니 새벽에 작업을 진행해서 업데이트를 해야 할 때도 있고, 프로그램이 죽거나 오류가 나는 상황을 빠른 시간안에 해결해야 하는 상황이 닥쳤을 때 법정 근로 시간이 무기력해 지는 시간이거든요. 업무 시간 외에도 해결을 해야 하거나 할 때 종종 생각이 들긴 합니다.

Q. 지나온 과거를 돌이켜볼 때, "아~ 그때로 돌아가면 이런 공부를 좀 하고 싶다"라는 게 있는지요?


일단 미리 공부해야 한다는 차원에서는 딱히 그런 건 없는 것 같습니다. 다 그 나이에 맞는 수준의 공부를 해야 한다고 생각하기 때문에 더 빨리 공부한다고 해서 더 나아지리라는 보장이 없다는게 제 생각입니다.
하지만 선택의 순간에서 다른 선택을 했을 때 아쉬운 건 있는데 대학원 진학을 못했던 것입니다. 그 당시에 저는 취업 보다는 조금 더 공부해서 소프트웨어 공학쪽이나 그래픽 UI 처리 쪽을 더 공부 하려고 했으나 집안 사정 때문에 취업을 할 수 밖에 없는 상황이었죠. 부모님의 바램대로 졸업 전에 취업을 해서 회사 생활을 쭉 해오긴 했지만 마음속 깊은 곳 한쪽에서는 대학원을 진학해 조금 더 연구과제에 대한 공부를 했으면 어땠을까 하는 아쉬움이 조금은 있긴 합니다.

Monday, October 8, 2018

프로그래밍 언어를 잘 아는게 실력 향상에 도움이 되는가?

여러 커뮤니티 사이트와 네이버 까페 등을 가보면서 junior 레벨의 프로그래머가 항상 궁금해 하는 것들이 여럿 있다.
  • 제가 javascript를 열심히 공부하면 서버 개발하는데 도움이 될까요?
  • 제가 java로 네트워크 소켓 프로그래밍은 해봤는데 c#으로 하려면 어떻게 해야 하는 거죠?
  • java 공부를 열심히 하면 취업 할 때 도움 되나요?
  • angularjs를 이용해서 front-end 개발한지 2년 됐습니다. vue.js가 핫하다는데 배우면 이직할 때 도움 되겠죠?
뭔가 다들 중요한 포인트를 놓친 채 프로그래밍 언어 혹은 프레임워크에 의존적인 얘기들만 하고 있다. 더 이상한건 경력이 조금 되는 친구들도 뭔가 다른 영역에 도전하는 걸 많이 두려워 하고, 새로운 걸 도전해 보고 싶기는 한데 생각만 가득한 채 실천도 못한채로 질문을 하는 경우도 많이 있다.

결론 부터 말하면 어떤 특정 프로그래밍 언어나 특정 프레임워크에 의존적인 개발을 하다 보면, 기본적으로 자기가 개발이라는 걸 잘 못하고 있거나 잘 모르고 있다는 전제가 깔려 있을 떄 그런 생각이 들고 질문을 하게 된다. 그리고 이런 걸 질문할 수준이면 자신이 여태까지 개발을 제대로 하고 있었던 건지 되돌아 볼 필요가 있다고 본다.

질문을 하나하나 짚어보면서 분석해 보면

javascript 를 열심히 공부해서 서버를 개발하고 싶다.


우선 javascript를 먼저 배울게 아니라 서버가 하는 역할이 뭐고, 어떤 프로토콜을 써서, 어떤 데이터를 주고 받고, DB에서 데이터를 빠르고 효율적으로 가져와서, 어떤 유용한 결과를 request한 쪽에 줄 건지를 먼저 고민해야 하는게 서버를 개발하는 거라 얘기해 주고 싶다. 그런데 이게 중요하다고 얘기를 해 줘도 자꾸 javascript를 배워야 한다는 생각 먼저 한다. javascript로 된 서버 코드 예제를 분석하고 돌려보고 하면 자기도 서버를 개발할 수 있게 될거라 생각하는 것 같다. 그런데 그런 식으로 하면 처음엔 쉽고 빠르게 되는 것 같아 보여도 결국 내가 처음에 언급한 내용을 되짚어 보면서 구현을 하게 되어 있다. 프로그래밍 언어를 잘 아는게 개발을 잘 하는거라 착각하고 있는 것이다.

java로 네트워크 소켓 프로그래밍은 해봤는데 C#으로는 어떻게 하는 건지 잘 모르겠다.


이 친구는 첫번째 친구보다 더 심각한 상태이다. 최소한 네트워크 프로그래밍을 해야 하는 이유와 네트워크 프로그래밍을 통해 클라이언트와 서버가 뭘 하고 싶어 하는 건지 알고 있다면 프로그래밍 언어를 잘 알고 모르고가 크게 중요하지 않다. 다른 프로그래밍 언어를 경험 안해봐서 그런 것 뿐이지 사실 java나 c#이나 배워서 익히는 수준은 대동소이 하다. 자기가 여태까지 해 왔던 프로그래밍 언어는 익숙하니까 이게 전부인줄 알고 열심히 한건데, 세상에는 같은 동작을 하지만 다양한 다른 프로그래밍 언어로 네트워크 프로그래밍의 비지니스 로직을 구현할 수 있다는 사실을 알아야 한다. 마치 java+spring 프레임워크를 배우는 것 만이 개발자 최종 테크트리의 끝판왕이라 생각하고 다들 미친듯이 java만 한다면 그렇게 java와 spring 프레임워크에 익숙해 지다가 다른 언어 다른 프레임워크를 만나게 됐을 때 뭔가 해볼 생각을 하지 않는다. 그게 문제인 것이다. 다시 생각해 보라 그게 진짜 프로그래머의 모습인지를.

java 공부를 열심히 하면 취업할 때 도움이 되는지


이미 앞에서 설명해서 더 추가로 설명해 보자면, 특정 프로그래밍 언어가 더 취업이 잘 되고 안되고가 정해져 있다면 다들 그 프로그래밍 언어를 하는게 더 득이 되는지 경제학적으로 생각해 보면 된다. 모두 다 취업에 유리한 java만 배웠다고 하면 상대적으로 java를 할 줄 아는 사람이 많아지게 된다는 거고, 대체할 수 있는 프로그래머의 인력 풀도 시장에 많다는 뜻도 된다. "너 아니어도 할 사람은 많다" 라는 말을 들으면 가슴이 아프겠지만 실제로 수요가 그렇게 만들어져 있다면 거기에 탑승한게 잘한건지 아닌지 본인 스스로 판단 가능하다.
그런 시장의 수요가 극단적으로 일어나는 분야를 얘기해 보면 html, css 할 줄 아는 웹 퍼블리셔 분야다. 이 직군에 채용공고를 올리면 하루에 신입 이력서만 30개나 올라온다. 이틀이 지나면 50개가 찬다. 거짓말 아니고 진짜다. 그 중에 CS 전공자는 한명 있을까 말까다. 반대로 OpenCV, Machine Learning 분야에 Python, C++ 할 줄 아는 사람 채용 공고를 올리면 이것도 거짓말 안하고 2~3일에 이력서 1개 올라온다. 그것도 신입으로 올라오는데 그나마 다행인건 CS 전공자가 생각보다 좀 있다는 거 정도다. 상황이 어렇다 보니 취업성공패키지로 취업시켜 준다고 하고 따라하기식 반응형 웹사이트 만들기 몇 달 한거 가지고 취업하려고 하니 취업이 잘 될리가 없다. 남들이 잘 안하는 걸 해보라. 그러면 실력이 형편 없어도 당신을 모셔갈 회사가 있을 가능성이 높다.
또 어떤 기술을 택해서 뭔가 해 봐야 취업이 되는 건 사실이나, 그 기술이 중요한게 아니라 그 기술로 뭘 해봤냐가 더 중요하다는 사실을 잊지 말아야 할 것이다. 로그인 세션 관리, 결제 페이지 연동, 게시판 관리 등등 실제 비니지스 로직을 구현하고 만들어낸 결과물이 뭔지 그 경험을 통해 내가 성취한 업적이 뭔지를 잘 설명하는게 중요한데도 단순히 java라는 프로그래밍 언어를 잘 하면 취업 잘 되냐는 되도 않는 소리를 하면 맥이 빠지는게 사실이다.
또 취업을 하기 위해 java를 열심히 할게 아니라 취업을 하기 위해 java로 프로그래밍 하는 게 적성에 맞고 즐거운지 한번 되돌아 보자. 취업하고 나서 적응 못하고 적성에 안맞아서 괴로운것 보다 내가 정말 하고 싶은게 취업이었는지 IT 기술을 배우고 그걸 익히는게 즐거웠는지를. 이 생각이 들 때가 되면 내가 java라는 기술을 배우고 익혔던게 크게 의미가 없다. 당장 마음이 불안하여 취업을 하는게 목표인 사람들이 생각 못하는 건, 내가 이 직업을 가지고 일하게 되면 즐거울지 아닌지에 대한 것이다.

angularjs를 이용해서 front-end 개발한지 2년 됐습니다. vue.js가 핫하다는데 배우면 이직할 때 도움 되는지


이 친구도 여태까지 웹이라는 걸 잘 생각해보지 않고 회사에서 시키는 대로 열심히 일하다 보니 2년이라는 시간을 보낸 안타까운 케이스인 거다. 이 친구의 신입 시절은 아마 절대 그렇지 않았을 것이다. 회사에서 주어진 업무를 빨리 배우고 익히면 스스로 잘 하게 될거라는 생각에 그냥 열심히 했을 것이다. 심지어 angularjs를 잘 알고 할 줄 아는게 잘못된 점도 아니라는 것이다. vue.js도 사실 해보고 경험해 보면 다른 경험을 할 수 있으니 이직할 때 조금이라도 도움이 되는 건 사실이다. 그런데 프론트엔드라는 것이 angularjs던 vue.js던 뭘 더 잘해야 하느냐가 중요한게 아니다. 프레임워크를 잘 쓴다는게 쓰고 경험해 보면 아는 것이지만, 조금이라도 직관적으로 그리고 조금 편하게 개발해서 생산성이 얼마나 될 것인지, 나중에 수정 및 유지보수가 쉬운지 등등 프레임워크가 가져야 하는 본연의 기능을 잘 훈련하는 것 즉 방법적인 것에 불과하다는 것이다.
그러니까 웹 프론트엔드 개발을 하는데 중요한게 어떤 프레임워크를 잘 쓸줄 아느냐가 아니라 어떤 목적을 가진 사이트를 개발할 거고 거기에 맞게 뭘 적용해서 해야 하느냐가 더 중요하다는 얘기다. 그런데 이미 angularjs를 통해서 웹에 대한 이해 프론트엔드에 대한 이해가 충분히 잡혀 있다면 다른 유사한 프론트엔드 프레임워크가 추구하는 가치가 뭔지, 특징이 뭔지 정도는 찾아보면 알 수 있는 건데도, 또 배워야 한다는 생각을 한다는게 잘못됐다는 것이다. 심지어 언어도 javascript로 같은데도 말이다.
닭 잡는데 소잡는 칼 쓴다는 논어에 얘기도 있듯이 웹 프론트엔드가 하는게 뭔지 한번이라도 조금 더 생각해 보면 angularjs를 잘 쓰냐 vue.js를 잘 쓰냐가 크게 중요하지 않을 수 있다는 뜻이다. 오히려 이런 프레임워크를 쓰는 방법을 익히는 것 보다 각각의 프레임워크가 어떤 작업을 하는데 효과적이고 효율적인지 알아보고 적용할 수 있는 안목을 키우는게 더 중요하다. 그런 안목을 키우는 차원에서 토이 프로젝트로 이것 저것 실험적인걸 해보는 수준이면 크게 나쁘지 않으며, 거기서 다른 프론트엔드 프레임워크와의 차이점을 발견할 수준이면 더 없이 좋을 것이다.
다시 정리하자면 이직할 때 도움이 되는게 vue.js 쓰는 법을 아는게 중요한 것이 아니라 현재 써 왔던 angularjs와 어떤 차이점이 있고 내가 뭘 만드느냐에 따라 어떤 프레임워크를 선택하느냐의 기준을 얘기할 수 있으면 충분히 도움이 될 것이다.

결론


프로그래밍을 오래 하다 보면 점점 특정 프로그래밍 언어 의존적, 프레임워크 의존적, 더 나아가서는 툴 의존적인 경력이 쌓이게 된다. 그런데 그 기간이 길어지면 프로그래밍 능력, 생각하는 능력, 발전적인 능력이 쌓인다기 보다는 일하는 방법에 대한 훈련과 반복되는 익숙함에 시간을 보내게 되어 있다. 그리고 시간이 가면서 스스로 내가 잘 하는지 못하는지 불안해 지지만 쉽게 자신의 손에 익숙한 언어, 프레임워크, 툴을 버릴 자신이 없어진다. 물론 비지니스 로직 처리 하면서 시켜서 해야 하는 일 외에 더 좋은 방법에 대해 고민하고 구현하고 정리해 봤다면 프로그래밍 능력이 조금 좋아질 가능성이 높긴 한데, 대부분 회사 일 하느라 바쁘다 보니 생각은 있어도 실천하기가 쉽지가 않다. 이 상태에서 또 다른 프로그래밍 언어를 배우는게 프로그래밍 능력을 향상시키는 방법이 아님에도 불구하고 다른 프로그래밍 언어를 배우는 것이 나의 개발 커리어도 쌓고 실력이 향상될 것이라고 굳게 믿고 있다. 물론 방법을 어떻게 하느냐에 따라 실력을 쌓을 수 있냐 아니냐가 다를 수 있지만, 그냥 튜토리얼 실행해 보기 책 따라해보기 정도로 깔짝대는 수준으로는 어림없다는 것도 알아야 한다.

기술적으로 프로그래밍의 실체를 접한 친구들은 "실무 일을 열심히 하는 것" = "프로그래밍 실력 향상" 이라는 착각을 하는데, 왜 이런 문제가 발생하는지 진지하게 고민해 보도록 하자. 그리고 이 때가 되면 기술 적인 배움 보다는 조금 더 학문적인 수준에서 접근을 해야 할 필요가 있다. 학문적인 것이라 해서 논문을 쓸 수준의 연구를 하라는 뜻이 아니라 프로그래밍 이외의 것들에 대해 접해보고 생각할 시간을 가져야 한다는 뜻이다. 그렇게 해서 프로그래밍이라는게 어떤 것이고 그것을 통해 어떤 결과를 얻고 싶은 것이며 그 과정 중에 왜 이렇게 코드를 짜야 하는지에 대한 이해를 해야 할 때가 실력이 높아질 수 있는 때이다. 이제 프로그래밍이라는 행위를 왜 하는지, 소프트웨어가 추구하고자 하는 본질이 무엇인지를 조금 더 생각해보자. 여태까지 해 왔던 프로그래밍 언어 의존적, 프레임워크 의존적인 개발을 해 왔던 생각이 많이 달라질 것이다.