Primitive Obsession
- Use of primitives instead of small objects for simple tasks (currency, ranges, phone numbers)
- Use of constants for coding info. (USER_ADMIN_ROLE = 1)
- Use of string constants as field names for use in data arrays.
-> Class may become huge and unwieldly.
Problem
- Class contains data field.
data:image/s3,"s3://crabby-images/34d6b/34d6b14b8e66da77a75e974dfd8657cc1cd3173a" alt=""
Solution (Replace Data Value With Object)
- Create a new class, place old field and its behavior in class, store the object of class in original class
data:image/s3,"s3://crabby-images/73bc8/73bc819e46c60aefd88fb6fb4d7efac49aeeaaaa" alt=""
Problem
- You have an array that contains various types of data
String[] row = new String[2];
row[0] = "Liverpool";
row[1] = "15";
Solution (Replace Array with Object)
- Replace array with object that will have separate fields for each element
Performance row = new Performance();
row.setName("Liverpool");
row.setWins("15");
Problem
- Repeating group of parameters
data:image/s3,"s3://crabby-images/e1e41/e1e41ce7434df2ac7b37b3572e4a89754a18f779" alt=""
Solution
- Replace parameters with object
data:image/s3,"s3://crabby-images/e6949/e69491cfca3ab627228ee20ad91451b8d1ebb54f" alt=""
Problem
- Class has fields that contain type code. These types aren't used in operator and don't affect problem behavior
data:image/s3,"s3://crabby-images/dfaa8/dfaa831b10185b0ddcf8b9b62cdbc1a015461fbf" alt=""
Solution
- Make new class and use its objects instead of type code values
![업로드중..]()
Long Parameter List
Data Clumps
- contain identical groups of variables
Object-Oriented Abusers Treatment
Null checker
data:image/s3,"s3://crabby-images/383d6/383d69f6e132aa380443a7b216372bf1dfae6317" alt=""
Replace Conditionals with polymorphism
data:image/s3,"s3://crabby-images/0cb82/0cb8243b24906692ffd4c389561ebed7c33da2f0" alt=""
Replace Parameter with Explicit Methods
data:image/s3,"s3://crabby-images/b9a2f/b9a2f4f9dc27eff1ba17b3e0ff75741457ae665f" alt=""
data:image/s3,"s3://crabby-images/05233/05233eb242d790eeaadb11ae47682266b4de5dc6" alt=""
Change Preventers
Dispensables
Couplers
함수 생성 규칙
1 호출되는 함수를 호출하는 함수보다 나중에 배치. (신문 기사 처럼 중요한 개념 우선 배치
2 서술적임 함수/변수명 사용. 의도가 분명한 이름 짓기. 주석 없이 직관적으로 이해할 수 있게끔 이름에 존재 이유? 수행 기능? 사용 방법?에 대해 답변을 할 수 있는 이름이어야 한다. 일관성 있고 검색하기 쉬운 이름 사용.
3 함수의 인수 최소화
4 함수는 최대한 작게 만들기. 함수는 한 가지만 잘해야 한다. 주석을 달아서 이해를 시키려는 함수면 보통은 함수가 너무 크다는 걸 수 있다.
5 변수 선언은 사용하는 위치에 최대한 가까이
6 인스턴스 변수는 클래스 맨 처음에 선언
불필요한 주석
1 함수나 변수를 설명하는 주석 (함수 변수명을 잘만들라)
2 저자 소개
3 주석으로 처리한 코드
4 너무 많은 정보
TDD
유연성, 유지보수성, 재사용성 고려하기
1 실패하는 단위 테스트 작성 전까지 실제 코드 작성 X
2 컴파일이 실패하지 않으면서 실행이 실패하는 정도의 단위 테스트 작성
3 현재 실패하는 테스트를 통과할 정도의 실제 코드 작성
프로그래밍은 과학보다 공예에 가깝다. 깨끗한 코드를 짜려면 지저분한(우선 돌아가는) 코드를 짠 뒤에 정리해야 한다.
REF
Clean Code 로버트 C. 마틴
https://refactoring.guru/