메뉴 바로가기 검색 및 카테고리 바로가기 본문 바로가기

읽기 좋은 코드가 좋은 코드다: 더 나은 코드를 작성하는 간단하고 실전적인 테크닉

한빛미디어

번역서

판매중

  • 저자 : 더스틴 보즈웰 , 트레버 파우커
  • 번역 : 임백준
  • 출간 : 2012-04-26
  • 페이지 : 252 쪽
  • ISBN : 9788979149142
  • 물류코드 :1914
  • 초급 초중급 중급 중고급 고급
1 2 3 4 5
4.5점 (6명)
좋아요 : 53

책소개

자신의 코드를 남에게 보여주기가 꺼려집니까?

프로그래머인 우리는 너무 엉망인데다가 버그투성이라서 머리가 지끈거리는 코드를 만나곤 한다. 이 책의 저자인 더스틴 보즈웰과 트레버 파우커는 지난 5년 동안 (자신들의 코드를 포함한) 수백 개의 "나쁜 코드"를 분석하고, 그러한 코드가 "왜 나쁜지", 그리고 코드를 "어떻게 개선할 수 있는지"를 연구했다. 그들이 내린 결론은 무엇일까? 그것은 바로 다른 사람들이 코드를 읽고 이해하는 데 걸리는 시간이 최소한이 되도록 작성해야 한다는 것이다. 여기에서 다른 사람이란 자기 자신도 포함된다!

체계적이고 효과적으로 코드를 작성하고 있나요?

이 책은 코드를 작성할 때 언제나 적용할 수 있는 기본적인 원리와 실전적인 기술에 초점을 맞추고 있다. 누구나 쉽게 이해할 수 있는 코드를 예제로 사용하고, 각 장은 코딩과 관련한 다양한 측면을 파고든다. 그리하여 여러분이 어떻게 이해하기 쉬운 코드를 작성할 수 있는지를 보여준다.
  • 딱 맞는 이름 짓기, 주석 달기, 포맷팅 등을 어떤 코드에도 적용할 수 있는 도움말과 함께 설명한다.
  • 프로그램의 루프, 논리, 그리고 변수를 정리해서 복잡성과 혼동을 감소시킨다.
  • 한 번에 하나의 일을 처리하도록 코드의 블록을 정리하는 등, 문제를 함수 수준에서 공략한다.
  • 철저하고 간결하면서 동시에 읽기 쉬운, 효과적인 테스트 코드를 작성한다.
추천평(추천사)

"자신이 작성한 코드가 나중에 그 코드를 읽게 될 사람에게 어떤 영향을 주는지 의식하는 일은 소프트웨어 개발의 중요한 일부다. 이 책은 독자로 하여금 바로 이러한 문제의식을 바탕으로 여러 측면을 경험하게 하고, 이러한 내용을 생생한 예를 통해서 효과적으로 설명한다"
- 마이클 헝거, 소프트웨어 개발자, 네오 데크놀로지

"이 책을 번역하기로 결정한 과정은 다소 우연이었지만, 번역을 하는 과정에서 내가 평소에 생각하던 부분들이 이렇게 책으로 정리되어 나왔다는 사실에 안도감과 고마움을 느꼈다. 내가 지금까지 경험한 바에 의하면, 이 책을 읽지 않아도 좋은, 원래부터 간결하고 효율적인 코드를 작성하는 능력을 가진 프로그래머는 열에 하나에 불과하다. 자신이 그 하나에 속한다는 확신이 없으면, 이 책을 꼭 읽어보기 바란다"
- 임백준, 소프트웨어 개발자 & IT 라이터

저자소개

더스틴 보즈웰 저자

더스틴 보즈웰

칼텍에서 컴퓨터 사이언스 학사학위를 받았고, UC 샌디애고에서 석사학위를 받았다. 5년 동안 구글에서 근무하면서 웹크롤링 인프라스트럭처를 비롯한 다양한 프로젝트를 경험했다. 수많은 웹사이트를 개발했고 "빅 데이터"와 "기계학습" 분야에 관심이 있다.
트레버 파우커 저자

트레버 파우커

10년 동안 마이크로소프트와 구글에서 대규모 소프트웨어를 개발했다. 지금은 구글에서 검색 인프라스트럭처의 엔지니어로 근무하고 있다. 여가 시간에는 게임 관련 컨벤션에 참석하고, 공상과학 소설을 읽고, 부인의 패션 관련 스타트업 회사에서 COO 일을 한다. 트레버는 UC 버클리에서 전기공학과 컴퓨터 사이언스 학사학위를 받았다.
임백준 역자

임백준

삼성전자 산하 삼성리서치의 AI센터에서 4년 동안 데이터 조직을 이끌었다. 이후 런던에서 삼성리서치 영국연구소 소장으로 근무했고 2024년 초에 한국으로 돌아와 한빛앤이라는 디지털 콘텐츠 플랫폼을 창업하여 CEO 역할을 맡고 있다.
2017년 한국에 들어오기 전까지 미국에서 살았고, 20년 동안 뉴욕 월스트리트의 다양한 회사와 스타트업에 다니며 소프트웨어 개발 업무를 수행했다. 뉴욕에서 일하던 시기에는 한국에 있는 개발자들을 대상으로 『행복한 프로그래밍』, 『누워서 읽는 알고리즘』, 『뉴욕의 프로그래머』 등 10여 권의 도서를 집필하였다. 그 이외에 기고, 강연, 팟캐스트 방송 등을 통해 활발한 활동을 벌였다.

 

목차

1장. 코드는 이해하기 쉬워야 한다   01. 무엇이 코드를 "더 좋게" 만드는가?     02. 가독성의 기본 정리     03. 분량이 적으면 항상 더 좋은가?     04. 이해를 위한 시간은 다른 목표와 충돌하는가?     05. 어려운 부분  PART I. 표면적 수준에서의 개선2장. 이름에 정보 담기   01. 특정한 단어 고르기     02. tmp나 retval 같은 보편적인 이름 피하기     03. 추상적인 이름보다 구체적인 이름을 선호하라     04. 추가적인 정보를 이름에 추가하기     05. 이름은 얼마나 길어야 하는가?     06. 이름 포메팅으로 의미를 전달하라     요약  3장. 오해할 수 없는 이름들   01. 예: Filter()     02. 예: Clip(text, length)     03. 경계를 포함하는 한계값을 다룰 때는 min과 max를 사용하라     04. 경계를 포함하는 범위에는 first와 last를 사용하라     05. 경계를 포함하고/배제하는 범위에는 begin과 end를 사용하라     06. 불리언 변수에 이름 붙이기     07. 사용자의 기대에 부응하기     08. 예: 이름을 짓기 위해서 복수의 후보를 평가하기     요약  4장. 미학   01. 미학이 무슨 상관인가?     02. 일관성과 간결성을 위해서 줄 바꿈을 재정렬하기     03. 메소드를 활용하여 불규칙성을 정리하라     04. 도움이 된다면 코드의 열을 맞춰라     05. 의미 있는 순서를 선택하고 일관성 있게 사용하라     06. 선언문을 블록으로 구성하라     07. 코드를 "문단"으로 쪼개라     08. 개인적인 스타일 대 일관성     요약  		5장. 주석에 담아야 하는 대상   01. 설명하지 말아야 하는 것     02. 생각을 기록하라     03. 코드를 읽는 사람의 입장이 되어라     04. 마지막 고찰 - 글 쓰는 두려움을 떨쳐내라     요약  	6장 명확하고 간결한 주석 달기   01. 주석을 간결하게 하라     02. 모호한 대명사는 피하라     03. 엉터리 문장을 다듬어라     04. 함수의 동작을 명확하게 설명하라     05. 코너케이스를 설명해주는 입/출력 예를 사용하라     06. 코드의 의도를 명시하라     07. 이름을 가진 함수 파라미터 주석     08. 정보 축약형 단어를 사용하라     요약  	PART II. 루프와 논리를 단순화하기7장. 읽기 쉽게 흐름제어 만들기   01. 조건문에서 인수의 순서     02. if/else 블록의 순서     03. (삼항 연산자로 알려진)?:를 이용하는 조건문 표현     04. do/while 루프를 피하라     05. 함수 중간에서 반환하기     06. 악명 높은 goto     07. 중첩을 최소화하기     08. 실행 흐름을 따라올 수 있는가?     요약  	8장. 거대한 표현을 잘게 쪼개기   01. 설명 변수     02. 요약 변수     03. 드모르간의 법칙 사용하기     04. 쇼트 서킷 논리 오용하기     05. 예: 복잡한 논리와 씨름하기     06. 거대한 구문 나누기     07. 표현을 단순화하는 다른 창의적인 방법들     요약  	9장. 변수와 가독성   01. 변수 제거하기     02. 변수의 범위를 좁혀라     03. 값을 한 번만 할당하는 변수를 선호하라     04. 마지막 예     요약  	PART III. 코드 재작성하기10장. 상관없는 하위문제 추출하기   01. 소개를 위한 예: findClosestLocation()     02. 순수한 유틸리티 코드     03. 일반적인 목적의 코드     04. 일반적인 목적을 가진 코드를 많이 만들어라     05. 특정한 프로젝트를 위한 기능     06. 기존의 인터페이스를 단순화하기     07. 자신의 필요에 맞춰서 인터페이스의 형태를 바꾸기     08. 지나치게 추출하기     요약  	11장. 한 번에 하나씩   01. 작업은 작을 수 있다     02. 객체에서 값 추출하기     03. 더 큰 예제     요약  	12장. 생각을 코드로 만들기   01. 논리를 명확하게 설명하기     02. 라이브러리를 알면 도움이 된다     03. 논리를 쉬운 말로 표현하는 방법을 더 큰 문제에 적용하기     요약  	13장. 코드 분량 줄이기   01. 그 기능을 구현하려고 애쓰지 마라 - 그럴 필요가 없다     02. 요구사항에 질문을 던지고 질문을 잘게 나누어 분석하라     03. 코드베이스를 작게 유지하기     04. 자기 주변에 있는 라이브러리에 친숙해져라     05. 예: 코딩 대신 유닉스 도구를 활용하기     요약  PART IV. 선택된 주제들	   14장. 테스트와 가독성   01. 읽거나 유지보수하기 쉽게 테스트를 만들어라     02. 이 테스트는 어떤 점이 잘못되었을까?     03. 이 테스트를 더 읽기 쉽게 만들기     04. 읽기 편한 메시지 만들기     05. 좋은 테스트 입력값의 선택     06. 테스트 함수에 이름 붙이기     07. 이 테스트 코드는 무엇이 잘못되었는가?     08. 테스트에 친숙한 개발     09. 지나친 테스트     요약  	15장. "분/시간 카운터"를 설계하고 구현하기   01. 문제     02. 클래스 인터페이스 정의하기     03. 시도1: 순진한 해결책     04. 시도2: 컨베이어 벨트 설계     05. 시도3: 시간-바구니 설계     06. 3가지 해결책 비교하기     요약  	Appendix 추가적인 도서목록   01. 높은 수준의 코드를 쓰는 방법을 다루는 책들     02. 다양한 프로그래밍 주제에 대한 책들     03. 역사적 사례를 담고 있는 책들     찾아보기

독자리뷰

오탈자 보기

결제하기
• 문화비 소득공제 가능
• 배송료 : 2,000원배송료란?

배송료 안내

  • 20,000원 이상 구매시 도서 배송 무료
  • 브론즈, 실버, 골드회원 무료배송
닫기

리뷰쓰기

닫기
* 상품명 :
읽기 좋은 코드가 좋은 코드다: 더 나은 코드를 작성하는 간단하고 실전적인 테크닉
* 제목 :
* 별점평가
1 2 3 4 5
* 내용 :

* 리뷰 작성시 유의사항

글이나 이미지/사진 저작권 등 다른 사람의 권리를 침해하거나 명예를 훼손하는 게시물은 이용약관 및 관련법률에 의해 제재를 받을 수 있습니다.

1. 특히 뉴스/언론사 기사를 전문 또는 부분적으로 '허락없이' 갖고 와서는 안됩니다 (출처를 밝히는 경우에도 안됨).
2. 저작권자의 허락을 받지 않은 콘텐츠의 무단 사용은 저작권자의 권리를 침해하는 행위로, 이에 대한 법적 책임을 지게 될 수 있습니다.

오탈자 등록

닫기
* 도서명 :
읽기 좋은 코드가 좋은 코드다: 더 나은 코드를 작성하는 간단하고 실전적인 테크닉
* 구분 :
* 상품 버전
종이책 PDF ePub
* 페이지 :
* 위치정보 :
* 내용 :

도서 인증

닫기
도서명*
읽기 좋은 코드가 좋은 코드다: 더 나은 코드를 작성하는 간단하고 실전적인 테크닉
구입처*
구입일*
부가기호*
부가기호 안내

* 온라인 또는 오프라인 서점에서 구입한 도서를 인증하면 마일리지 500점을 드립니다.

* 도서인증은 일 3권, 월 10권, 년 50권으로 제한되며 절판도서, eBook 등 일부 도서는 인증이 제한됩니다.

* 구입하지 않고, 허위로 도서 인증을 한 것으로 판단되면 웹사이트 이용이 제한될 수 있습니다.

닫기

해당 상품을 장바구니에 담았습니다.이미 장바구니에 추가된 상품입니다.
장바구니로 이동하시겠습니까?