📚책 정보
- 좋은 코드, 나쁜 코드 (2022)
- 톰 롱 (구글 소프트웨어 엔지니어) 지음
📝1장: 코드 품질
1. 코드는 어떻게 소프트웨어가 되는가
2. 코드 품질의 목표
3. 코드 품질의 핵심 요소
4. 고품질 코드 작성은 일정을 지연시키는가?
📍주석의 역할
- 주석은 그 코드가 무슨 일을 하는지가 아니라, 그 코드가 왜 거기 있는지를 설명해야 한다
📍코드 퀄리티를 나누는 것은
- 객관적으로 코드의 품질을 평가하려면, 코드를 통해 달성하려는 것(본질적인 목표) 에 대해 생각해야 함
- 본질적인 목표에 도움이 되면 고품질의 코드, 방해가 되면 저품질의 코드
📍코드를 작성할 때 목표로 삼을 4가지
1. 기본적으로 코드가 잘 작동해야 함
2. 코드는 작동이 멈추면 안된다
- 현재는 잘 돌아가지만, 미래에 특정 조건이 변경됨에 따라 제대로 동작하지 않는다면, 그 코드는 별로 유용한 코드가 아니다
3. 코드는 변경된 요구사항에 적응할 수 있어야 함
- 사용자 선호, 새로운 기능의 추가에 잘 대응해야 함
- 처음부터 모든 변경사항에 대응 가능할 코드를 짜며 시간을 많이 잡아먹지 않도록 해야 함 => 미래 예측이 잘못 됐다면?
- 현재의 요구사항만 정확히 반영한 빠른 코드 작성 => 새 요구사항 대응을 위해 새로 짜야 하는 지경..
4. 이미 존재하는 기능을 중복 구현하면 안됨
- 개발 리소스 절약 가능
- 버그 가능성을 줄여줌 (앞서 검증된 코드)
- 이해하기 쉬움 (팀원들이 익숙한 기능)
📍코드 품질의 핵심요소
1. 가독성
2. 예측 가능성
- 예상과 다른 역할을 수행한다면 혼란을 초래
3. 코드를 오용하기 어렵게 만들기
- 코드를 사용하는 팀원이 잘못 사용하여 버그를 초래할 위험
4. 모듈화
- 갈아끼우기 쉬운 코드
5. 재사용성, 일반화 추구
- 개발 리소스를 절약, 미리 검증된 코드
6. 테스트 용이성
- 테스트하기 위해 코드를 많이 짜야 한다면..
- 테스트 용이성을 위해 코드 작성 시 테스트 용이성을 고려해야 함
- 코드를 다 작성하고 테스트를 고려하는 것이 아니다