코드를 점진적으로 개선하기
목차
1. 책의 예제
2. 점진적으로 개선하기
3. IDE를 활용해 점진적으로 개선하기
1. 책의 예제
명령형 인수 구문 분석기
코드 초안
- 모든 로직이 하나의 클래스에 들어가있다.
- 처음부터 지저분한 코드를 짜려는 생각은 없었고, 코드를 어느정도 손봤지만 새로운 인수 유형이 들어오면서 재양이 시작됐다.
- 이제는 개선해야 할 때라는 걸 깨닫고, 변경 전후 시스템이 동일하게 돌아간다는 사실을 확인하기 위해 테스트들을 작성해뒀다.
- 자잘하게 점진적으로 개선해나갔다.
코드 완성본
- Args 클래스에서 코드 중복을 최소화하고, ArgsException 클래스를 분리했다. ArgumentMarshaler 클래스를 통해 여러 인수에 대한 추후 확장성을 만들어냈다.
- 코드만 분리해도 설계가 좋아진다. 관심사를 분리하면 코드를 이해하고 보수하기 훨씬 더 쉬워진다.
2. 점진적으로 개선하기
1. 코드가 나빠지고 있음을 느꼈을 때 기능을 추가하지 않고 개선을 시작한다.
2. 변경을 가한 후에도 시스템이 변경 전과 똑같이 돌아가야 한다. 테스트 코드가 없다면 작성하고, 코드를 수정하기 전 상태에서 모든 테스트가 통과해야 한다.
3. 책임에 따라 클래스를 나누고, 코드를 옮긴다. 테스트가 깨지지 않도록 확인하며 자잘한 변경을 조금씩 진행한다.
"프로그램을 망치는 가장 좋은 방법 중 하나는 개선이라는 이름 아래 구조를 크게 뒤집는 행위다"
3. IDE를 활용해 점진적으로 개선하기
Intellij
mac 기준(Window는 command = Ctrl, option = Alt)
메서드 추출 기능 : command + option + m
메서드 파라미터를 추가하거나 변경 기능 : command + f6
메서드나 변수 이름 변경 : Shift + f6
변수 추출 기능 : command + option + v
특정 값을 멤버 변수로 설정하는 기능 : command + option + f
특정 값을 상수로 추출 기능 : command + option + c
하위 클래스의 메서드를 상위로 올리거나, 상위 클래스의 메서드를 하위로 내릴수 있는 기능 :
해당 메서드에서 마우스 오른쪽 클릭 후
'Book > Clean Code' 카테고리의 다른 글
[Clean Code] Chapter 13 (0) | 2022.03.31 |
---|---|
[Clean Code] Chapter 12 (0) | 2022.03.28 |
[Clean Code] Chapter 11 (0) | 2022.03.27 |
[Clean Code] Chapter 10 (0) | 2022.03.26 |
[Clean Code] Chapter 09 (0) | 2022.03.21 |