덕토피아

· 이것저것
벌써 2023년이 하루도 남지 않았습니다. 미루어왔던 올해 회고 글을 작성하면서 내년의 계획도 세워보고자 합니다. 좋았던 점은 파란색으로, 아쉬웠던 점은 빨간색으로 표시하겠습니다. 2023년 회고 [ 개발 공부에 집중하기 ] [리뷰] 개발자를 위한 글쓰기 가이드 [리뷰] 좋은 코드, 나쁜 코드 [리뷰] 객체지향의 사실과 오해 [리뷰] 프로그래머의 길, 멘토에게 묻다 [리뷰] 육각형 개발자 [리뷰] 스트리트 코더 [리뷰] 필독! 개발자 온보딩 가이드 [강의] 유데미 기술블로그로 알아보는 테크니컬 라이팅 수강 후기 올해는 관심 있는 분야의 다양한 개발서적과 강의를 보았습니다. 읽었지만 아직 리뷰를 쓰지 않은 것들도 있어서 이만하면 꽤나 선방했다고 할 수 있겠네요. 조금 아쉬운 것은 리뷰 포스팅을 미룬 것입니..
· 이것저것
"기술"이라는 특정한 주제로 글을 작성하는 데 어려움을 느꼈다면 추천드리고 싶은 강의가 있습니다. 바로 유데미의 기술블로그로 알아보는 테크니컬 라이팅 강의입니다. 총 강의 시간도 약 2시간으로 부담 없이 들어볼 수 있고, 저도 바로 그런 점에서 끌려 수강을 시작하였습니다. 결과는 대만족. 시간을 들여서 완강할만한 강의라는 판단이 들었습니다. 오늘 포스팅에서는 강의를 들으며 습득한 정보를 조금이나마 풀어보겠습니다. 더 많은 정보를 자세하게 얻고 싶다면 역시 강의를 직접 듣는 것이 가장 좋은 선택이겠죠? 테크니컬 라이팅이란 기술 글쓰기로, 풀어 쓰자면 특정 독자를 대상으로 특정 목적을 갖고 특정 정보를 전달하는 글쓰기입니다. 여기서 "특정"이라는 단어가 많이 나왔는데요. 그만큼 일반 문학과 테크니컬 라이팅에..
· 개발서적
언제 한 번 서점에 들렀을 때 우연히 발견한 책이었는데요. 내용을 살짝 훑어보니 유용한 내용이 많은 것 같아 시간이 나면 읽어봐야지 하고 벼르고 있었습니다. 근데 운 좋게 예전에 책 검수에 기여했던 일의 보상으로 책만 출판사의 책을 한 권 고를 수 있게 되어 냉큼 이 책을 골랐습니다. 총 14장으로 되어있고 한 장 한 장 모두 알찬 내용들로 담겨 있었습니다. 목차를 나열하면 다음과 같습니다. 1장. 여정을 시작하며 2장. 역량을 높이는 의식적 노력 3장. 코드와 함께 춤을 4장. 운영 환경을 고려한 코드 작성 5장. 피할 수 없는 코드 의존성의 관리 6장. 테스트! 개발자의 든든한 지원군 7장. 올바로 주고받는 코드 리뷰 8장. 고객 앞으로! 소프트웨어 전달 9장. 긴급대응 온콜 업무 10장. 견고한 소..
· 레퍼런스
처음 컬리에 입사했을 때 팀 내에서는 Java/Spring 스택으로 백엔드 개발을 진행하고 있었습니다. 이전 회사에서도 같은 스택을 사용해서 적응하기에 별 무리 없겠구나~ 했는데 웬걸, 프로젝트 구조가 그동안 봐왔던 것과는 상이했던 거였죠. 원래는 계층형 아키텍처를 사용하였습니다. 흔히 백엔드 개발을 시작하면 배우게 되는 그 Controller/Service/Repository 구조입니다. 가장 단순하고 이해하기 쉬운 구조여서 그런지 학생들을 가르칠 때도 많이 사용하죠. 저도 예외는 아니었습니다. 그러나 마주친 것은 이름조차도 낯선 헥사고날 아키텍처(Hexagonal Architecture)였습니다. 어댑터, 유스케이스, 포트 등 현란한 용어들 사이에서 저는 정신을 차릴 수가 없었습니다. 헥사고날 아키텍..
· 개발서적
길벗 출판사에서 IT 도서 리뷰 요청 제의가 들어왔습니다. 한 달이라는 기한을 잡았는데, 차일피일 미루고 급한 작업이 생기다 보니(변명이겠죠) 마감일을 꽉 채워서 포스팅을 쓰게 되었습니다. 스트리트 코더(Street Coder)란, '이 바닥'에서 여러 시행착오를 겪으며 배웠다는 뜻입니다. 독학으로 마이크로소프트 엔지니어가 된 저자가 시행착오를 겪으며 몸소 깨달은 생존 법칙과 노하우를 집필하였습니다. 실무 경험에 뿌리를 둔 현실적인 조언을 하는 책으로, 주니어 ~ 시니어 모두 읽기 좋은 책입니다. 특히 실무 경험이 없는 신입이 학교에서는 배울 수 없는 노하우로 시야를 넓히고 경험의 차이를 좁힐 수 있을 것입니다. 개발자로 살아가며 저희가 알아가는 중요한 이론들이 있죠. 컴퓨터 과학, 알고리즘, 클린 코드..
자바 언어로 개발하다 보면, 다양한 어노테이션을 활용할 때가 많습니다. 도대체 내부가 어떻게 되어있는지 궁금해서 들어가 보면, 알 수 없는 이상한 코드들과 마주칩니다. 어노테이션을 직접 생성하거나 유심히 공부해보지 않았다면 처음 보는 코드가 많을 겁니다. 비교적 자주 사용하는 @Getter 어노테이션인데도, 내부를 까보면 마치 외계어처럼 낯설기만 합니다. 이번 포스팅에서는 어노테이션이 무엇인지, 종류에는 어떤 것이 있는지, 그리고 샘플 코드를 통해 어노테이션을 조금 더 깊게 알아봅시다. 끝에는 이 낯선 @Getter 코드도 조금은 이해할 수 있을 것입니다. 어노테이션이란? 어노테이션이란 과연 무엇일까요? 단순히 앞에 골뱅이(@) 기호를 붙인 것일까요? 사용법으로는 맞지만, 우리가 원하는 어노테이션의 정의..
· 개발서적
한빛미디어에서 책 리뷰 협업 제의가 들어왔습니다. 당시 좀 긴 분량의 책(600p 이상)을 읽고 있었고, 기분 전환이 되겠다 싶어 수락하였습니다. 제의가 들어온 책은 "도메인 주도 개발 시작하기"의 최범균님의 신작, "육각형 개발자"입니다. 책은 주니어 개발자가 시니어 개발자로 성장하기 위한 핵심 역량에 대해 소개하고 있습니다. 총 11장으로 이루어져 있고, 270페이지가 조금 넘습니다. 신경 써서 본다면 일주일이면 충분히 완독할 분량입니다. 각 장의 내용은 다음과 같습니다. 책의 목차 1장. 들어가며 2장. 구현기술과 학습 3장. 소프트웨어 가치와 비용 4장. 코드 이해 5장. 응집도와 결합도 6장. 리팩터링 7장. 테스트 8장. 아키텍처, 패턴. 9장. 업무관리 10장. 정리하고 공유하기 11장. 리..
어떤 웹 페이지에 들어갔을 때 404 Not Found, 혹은 503 Service Unavailable 같은 문장을 본 적이 있을 것입니다. 개발자가 되기 전에는 그저 원하는 결과를 보지 못해 짜증만 유발하였는데, 이제는 코드가 대략적인 원인을 파악하게 만들어주는 고마운 녀석들이라는 것을 압니다. 그러나 기본적인 코드(200, 404)를 제외하고 여전히 아리송한 상태 코드들이 많습니다. 각 코드의 의미에 맞는 적절한 사용을 위해 이번 포스팅에서는 자주 보는 HTTP Status Code에 대해 알아봅시다. Status Code가 뭔가요? 요청이 성공적이었는지의 여부를 빠르게 검사할 수 있는 세 개의 숫자로 구성된 코드입니다. 기본적으로 100번에서 500번대 까지 5개의 그룹으로 나뉘어 있으며, 코드의..
코딩을 하다 보면, 정말 수많은 예외와 마주치게 됩니다. 그러나 예외에는 어떤 종류가 있는지, 어떤 상황에서 예외가 발생하는지 자세히 들여다볼 기회가 없었습니다. 이번 포스팅에서는, 자바 예외의 종류와 각각 어떤 Exception이 속해 있는지 알아봅시다. 3가지 예외 자바 예외는 크게 3가지 유형으로 나누어집니다. Checked Exception: 명시적으로 처리해야 하는 예외 (IOException, FileNotFoundException 등) Unchecked Exception: RuntimeException 상속. 명시적인 예외 처리를 강제하지 않음 (NullPointerException 등) Error: 시스템에 비정상적인 상황이 발생한 경우 (StackOverflowError 등) 쉽게 설명하..
· 개발서적
프로그래머가 되고 싶다면.. 소프트웨어 개발 분야에서 경력의 시작을 설계하고 이 분야에서 탁월한 개발자가 될 수 있도록 자기 자신을 세우는 일에 관한 책이다. 프로그래밍을 생업으로 삼으며 견습이라고 부를 만한 시기에 어떻게 행동해야 이상적인 길을 걸을 수 있을지, 정말로 제대로 배우려면 어떤 마음가짐이어야 하는지, 커뮤니티를 어떻게 활용해야 내게 도움이 되는지 등 구체적인 상황과 해결책을 멘토의 조언을 빌어 제시한다. 경험이 적은 소프트웨어 개발자들이 흔히 마주치는 딜레마에 대한 해결책을 공유합니다. 추천 독자는 소프트웨어 개발이 무엇인지 알게 되면서 이제 훌륭한 소프트웨어 개발자로 성장하기를 열망하는 사람들 이니, 시니어보다는 주니어에게 더 적합한 책입니다. 개발자들이 마주치는 여러가지 문제 상황을 제..
둘기덕
'분류 전체보기' 카테고리의 글 목록 (3 Page)