코드 품질 개선 기법 29편: 고르디우스 변수
문제로컬·원격 데이터 동기화 클래스에서 ID 집합 비교 결과를 `localEntryIds`, `remoteEntryIds` 변수에 담아 추가·업데이트·삭제 분기를 만들면, 변수 하나로 여러 의미가 묶여 "고르디우스 변수" 가 된다.
접근의도별로 변수를 잘라낸다. `idsToAdd`, `idsToUpdate`, `idsToDelete` 처럼 결과 집합을 미리 계산한 뒤 각 처리에 그대로 전달한다. 비교식 `id !in localEntryIds && id in remoteEntryIds` 같은 표현을 변수명으로 흡수.
결과분기 조건이 변수명으로 자기 설명적이 되고, 분기마다 의미가 명확해진다. 코드 리뷰 시 변수 한 개에 여러 책임이 묶인 패턴을 식별하는 안티패턴으로 정착시킨다.
이 글과 비슷한
- 백엔드·
stackoverflow-blog·#cpp#reflection#metaprogramming+1 - 백엔드·
네이버페이·Composite PK에서 시작된 Spring Boot 4 / Spring Batch 6 업그레이드 기록
문제Spring Data JDBC 의 Composite ID 적용을 위해 Spring Boot 3.5 → 4.0.1 업그레이드 시 Spring Batch, Kotlin, Jackson 등 전체 스택 메이저 전환 필요.
접근Spring Boot 4 / Spring Batch 6 / Spring Framework 7 / Kotlin 2.3 / Jackson 3 / Kotest 6 / Gradle 9 / ojdbc11 순차 업그레이드. Composite ID 는 Persistable 인터페이스로 구현, JdbcDefaultBatchConfiguration 상속으로 메타데이터 저장.
결과기술 부채 해결 + 장기 유지보수성 개선. 운영 DB 접근 정책 충돌을 사전 식별해 안정적 배포 달성.
#kotlin#spring#spring-boot+3 - 백엔드·
airbnb-eng·Skipper: Building Airbnb’s embedded workflow engine
#airbnb#workflow-engine#skipper+1