[책 리뷰] 클린 코드(로버트 C.마틴)
-------------------------------
<책 정보>
제목 : 클린 코드 (애자일 소프트웨어 장인 정신)
로버트 C.마틴 지음 / 박재호, 이해영 옮김
출판사: 인사이트
-------------------------------
<2장 의미 있는 이름>
습관적으로 이름을 짧게 지으려고 했는데, 그보다는 길더라도 의미와 역할이 분명한 이름이 좋다.
<3장 함수>
함수 인수의 개수는 적을 수록 좋다. 너무 많아지면 클래스로 분리, 클래스 내 프로퍼티로 승격 등을 고려해보자.
결과를 담당하는 변수, 객체를 함수 인자로 넣으면 읽는 입장에서 헷갈림. 함수 인자는 '인풋'의 역할이라는 것이 일반적인 생각이기 때문.
함수 인자를 1개로 쓰는 경우 -> 1. is, has나 같이 변수의 속성 확인 2. 인풋을 변환하여 아웃풋으로 받고자 할 때
<4장 주석>
주석이 나쁜 코드를 무마하려는 짓인 것을 깨달았다. 주석은 가독성에 도움이 되지 않는다. 애매한 코드를 주석으로 보완하려 하지 말자.
하지만 도움이 될 때도 있으니 잘 생각하자.
<5장 형식 맞추기>
적절한 가로길이, 세로 길이를 맞추어 가독성을 높이자. 가로로 너무 길어도 안 좋고 세로로 너무 긴 코드도 보기 싫다.
특정 함수에서 호출하는 프라이빗 함수는 그 바로 뒤에 두어 함수 간 수직거리를 짧게 유지하자.
적절한 공백은 가독성을 높여준다.
<6장 객체와 자료 구조>
<7장 오류 처리>
의미있는 예외를 만들어 예외 이름만으로 의도가 드러나도록 한다.
null을 전달하거나 반환하지 말자. 실수하기 쉬움(ex) 널체크 빼먹기). 자바에서는 Optional을 활용하자. 코틀린에서는 널허용 객체를 사용하자.
<8장 경계>
<9장 단위 테스트>
테스트에서 가장 중요한 건 가독성! 핵심이 아닌 것은 잘 숨겨보자.
<10장 클래스>
단일책임의 원칙에 의해, 클래스는 나눌 수록 좋은 것 같다.
응집도란 클래스내 변수가 클래스내의 메서드와 얼마나 밀접한지에 관한 지표다. 모든 변수들이 모든 메서드에서 사용되면 그 클래스는 응집도가 높은 것이고, 변수들이 하나의 메서드에만 사용되면 그 클래스는 응집도가 낮은 것이다.
응집도가 낮은 경우 클래스 분리를 할 수 있는 여지를 주는 것이기 때문에, 클래스 분리를 생각해보자.
<11장 시스템>
일단 어렵고 생소한 용어가 많아 읽을 때 재미가 없었다. 그래서 이해도 잘 안됐다. 대충 관점지향 프로그래밍이 좋다는 것을 말하는 듯 하다.
<12장 창발성>
창발이라는 용어가 어려운데, 만들 창에 발생할 발이다. Emergence로 번역된다.
근데 이 챕터 이름이 왜 창발성이지? 켄트 벡이 제시한 다음의 설계 규칙 네 가지를 잘 따르면, 우수한 소프트웨어 설계의 창발성을 촉진한다고 한다.
1. 모든 테스트를 실행 2. 중복 제거 3. 프로그래머의 의도를 표현 4. 클래스와 메서드 수를 최소로 줄임
<13장 동시성>
동시성 프로그래밍은 아직 어렵다. 나중에 다시 읽어야 될 거 같다.
<14장 점진적인 개선>
실제 코드 리팩토링을 보여준다. 앞서 소개한 원칙들을 실제로 적용하는 느낌.
<15장 JUnit>
junit 프레임워크를 간략히 소개하고, 그 중 코드 하나를 리팩토링한다.
<16장 SerialDate 리팩토링>
역시 이 챕터도 리팩토링.
<17장 냄새와 휴리스틱>
코드에서 나는 온갖 냄새들을 소개한다. 앞 내용과 많이 중복된다. 그 동안 전달하고자 했던 원칙들을 총 정리해주는 느낌.
- 마치며
책 들어가는 글에서 책이 세 부분으로 나눠진다고 했는데(원칙과 패턴 - 사례 연구 - 결말),
1~13 / 14~16 / 17 정도로 나눠지는 게 아닐까 생각한다.
14~16은 설명과 코드를 번갈아 봐야하는 불편함이 큰데(그래서 너무 힘듦), 저자가 이 불편함을 버티면서 코드를 분석해보기를 강조하므로 나중에 한번 더 읽어봐야겠다.