서브메뉴

본문

리팩토링 (코드 품질을 개선하는 객체지향 사고법)
리팩토링 (코드 품질을 개선하는 객체지향 사고법)
저자 : 마틴 파울러
출판사 : 한빛미디어
출판년 : 2012
ISBN : 9788979149715

책소개

객체지향 사고법을 정리한 이론서!

프로그램의 가치를 높이는 코드 정리 기술『리팩토링: 코드 품질을 개선하는 객체지향 사고법』. 리팩토링은 코드의 동작이나 의도는 유지하면서 코드의 구조, 재사용성, 가독성을 개선해 코드의 악취를 제거하고 전체 디자인을 개선하는 방법이다. 이 책은 72가지 리팩토링 기법을 통해 코드를 점진적으로 개선하는 방법을 소개한다. 특히 전문가 집단의 축적된 노하우를 바탕으로 리팩토링을 언제 어디에 어떻게 적용하면 되는지 상세히 설명하였다. 아울러 부록으로 설계적 문제점이 의심 가는 상황에 관한 대응 기법 표를 제시하여 적절한 기법을 쉽게 찾아 적용할 수 있도록 안내하였다.
[교보문고에서 제공한 정보입니다.]

출판사 서평

이 책이 제시하는 핵심 내용
코드 품질을 개선하는 객체지향 사고법을 정리한 참고서

어떤 독자를 위한 책인가?
좋은 코드를 작성하고, 코드의 품질을 개선하고 싶은 1-2년차 개발자
자바로 객체지향 프로그래밍을 제대로 하고 싶은 개발자

객체지향은 제대로 잘 해야 한다!

·당신은 객체지향 프로그래머인가?

프로그램이 돌아가기면 하면 객체지향인가? 객체지향이라는 도구를 제대로 활용하지 못하고 마구잡이로 작성한 코드에는 악취가 진동한다. 리팩토링은 코드의 동작이나 의도는 유지하면서 코드의 구조, 재사용성, 가독성을 개선해 코드의 악취를 제거하고 전체 디자인을 개선하는 방법이다.
독자는 72가지 리팩토링 기법을 통해 코드를 점진적으로 개선하는 방법을 학습할 수 있으며, 이 책을 마쳤을 때는 객체지향 프로그래밍 능력이 한 단계 향상될 것이다.

코딩 스타일이 바뀐다
객체지향 언어의 문법을 익혔다고 저절로 객체지향 프로그래밍을 할 수 있는 게 아니다. 리팩토링 카탈로그를 통해 어떤 코드를 고쳐야 하는지, 왜 고쳐야 하는지, 고친 코드가 왜 좋은지 이해할 수 있다. 이런 과정을 통해 객체지향에 어울리는 코드 디자인을 배우게 되고, 자신의 코딩 스타일도 바뀌게 된다. 이 책을 읽기 전과 후는 코드의 품질에 결정적인 차이를 가져오게 된다.

옮긴이 서문
프로그래밍할 때는 미리 구상 단계를 거치므로 설계는 목표만큼은 아니더라도 최소한의 완성도를 갖추리라 기대한다. 처음부터 완벽에 가까운 프로그램이 만들어진다면 얼마나 좋을까? 물론 경력이 많은 전문가가 시장 조사에서부터 요구사항과 문제 분석을 철저히 거쳐 소프트웨어 기획과 설계 단계에 이르는 심사숙고의 산물로 어느 정도 완성도 높은 프로그램을 제작할 수 있을지는 모른다. 하지만 최초에 탄탄한 설계를 갖추어도 어차피 시간이 흐르면 각종 요구사항의 증가와 변화로 프로그램에 기능을 추가하거나 수정하기 마련이고, 그렇게 버전 업이 이뤄졌을 때 겉으론 아무 문제가 보이지 않고 원활히 실행되는 것처럼 보여도 기저의 설계는 초기 의도와 달리 변형되고 왜곡되어 간다. 이러한 과정이 누적되어서 코드가 복잡해지면 작성자조차도 알아보기 힘들게 되어 유지보수가 어려워지고, 급기야 수정 보완할 때 치명적인 실수를 할 수도 있다. 처음엔 모든 제품이 새것이지만 시간에 따라 노후되듯이 소프트웨어도 지속적인 구조의 개선 없이는 차츰 노후되고 거기에 반영된 원래 목적도 퇴색한다. 그래서 탄탄한 설계부터 갖추는 것보다는 포괄적으로 소프트웨어를 완성하고 나서 의혹이 드는 점이 생기면 그때마다 지속적으로 설계를 보완하고 수정해 나가는 방식이 오히려 시간이 흐를수록 소프트웨어를 더욱 탄탄하고 안정화할 수 있다. 이런 지속적 보완을 점증적이고 체계적으로 해나갈 수 있는 도구가 바로 리팩토링이다. 리팩토링은 수년간의 경험을 통해 발견한 구체적인 소프트웨어 개선 방법들의 공통 해결책을 발견해 일반화한 추상 개념이다. 리팩토링은 기존의 소스코드를 가독성 readability, 재활용 reusability, 체계적 구조 well-structured 측면에서 개선하는 총괄 작업을 뜻한다. 설계를 좋아지게 고치면 구조가 체계적이 된다. 구조가 좋아지면 가독성과 재활용성은 저절로 얻는다.
이 책은 전문가 집단의 축적된 노하우를 바탕으로 리팩토링을 언제 어디에 어떻게 적용하면 되는지 상세히 알려준다. 흔히 발견되는 구린내(설계적 문제점이 의심 가는 상황)만 확실히 알아두면, 모든 기법을 외울 필요 없이 각 미심쩍은 상황마다 부록에 수록한 구린내에 따른 대응 기법 표를 참고해서 적절한 기법을 쉽게 찾아 적용할 수 있어서 현장 활용도가 높다. 예술 작품도 한 번에 완성되지 않는다. 어느 것이든 전체적 구상을 실체화한 후 각 부분을 보완하고 다듬고 덧입혀서 만들어지듯이, 소프트웨어도 적절하고 꾸준한 구조 수정과 보완이 필요하다.
부족한 저에게 이 책의 번역을 믿고 맡겨주신 송성근 팀장님과 한동훈 대리님께 감사하고, 항상 번역에만 집중할 수 있게 물심양면 뒷받침해주시는 한빛미디어 모든 분께 늘 감사 인사를 전한다. 이번 겨울을 보내며 제 자신도 한 층 더 발전하는 시간이 되기를 바란다.
- 김지원
[교보문고에서 제공한 정보입니다.]

목차정보

CHAPTER 01 맛보기 예제
원래의 프로그램
리팩토링 첫 단계
statement 메서드 분해와 기능 재분배
가격 책정 부분의 조건문을 재정의로 교체
고찰

CHAPTER 02 리팩토링 개론
리팩토링은 무엇인가
리팩토링은 왜 해야 하나
리팩토링은 어떨 때 필요한가
팀장에게 어떻게 말을 꺼내나
리팩토링 관련 문제들
리팩토링과 설계
리팩토링과 성능
리팩토링의 유래

CHAPTER 03 코드의 구린내
중복 코드 Duplicated Code
장황한 메서드 Long Method
방대한 클래스 Large Class
과다한 매개변수 Long Parameter List
수정의 산발 Divergent Change
기능의 산재 Shotgun Surgery
잘못된 소속 Feature Envy
데이터 뭉치 Data Clumps
강박적 기본 타입 사용 Primitive Obsession
switch 문 Switch Statements
평행 상속 계층 Parallel Inheritance Hierarchies
직무유기 클래스 Lazy Class
막연한 범용 코드 Speculative Generality
임시 필드 Temporary Field
메시지 체인 Message Chains
과잉 중개 메서드 Middle Man
지나친 관여 Inappropriate Intimacy
인터페이스가 다른 대용 클래스 Alternative Classes with Different Interfaces
미흡한 라이브러리 클래스 Incomplete Library Class
데이터 클래스 Data Class
방치된 상속물 Refused Bequest
불필요한 주석 Comments

CHAPTER 04 테스트 작성
JUnit 테스트 프레임워크
테스트 추가

CHAPTER 05 리팩토링 기법 카탈로그에 대해
참조 검색
리팩토링 기법의 성숙도

CHAPTER 06 메서드 정리
메서드 추출 Extract Method
메서드 내용 직접 삽입 Inline Method
임시변수 내용 직접 삽입 Inline Temp
임시변수를 메서드 호출로 전환 Replace Temp with Query
직관적 임시변수 사용 Introduce Explaining Variable
임시변수 분리 Split Temporary Variable
매개변수로의 값 대입 제거 Remove Assignments to Parameters
메서드를 메서드 객체로 전환 Replace Method with Method Object
알고리즘 전환 Substitute Algorithm

CHAPTER 07 객체 간의 기능 이동
메서드 이동 Move Method
필드 이동 Move Field
클래스 추출 Extract Class
클래스 내용 직접 삽입 Inline Class
대리 객체 은폐 Hide Delegate
과잉 중개 메서드 제거 Remove Middle Man
외래 클래스에 메서드 추가 Introduce Foreign Method
국소적 상속확장 클래스 사용 Introduce Local Extension

CHAPTER 08 데이터 체계화
필드 자체 캡슐화 Self Encapsulate Field
데이터 값을 객체로 전환 Replace Data Value with Object
값을 참조로 전환 Change Value to Reference
참조를 값으로 전환 Change Reference to Value
배열을 객체로 전환 Replace Array with Object
관측 데이터 복제 Duplicate Observed Data
클래스의 단방향 연결을 양방향으로 전환 Change Unidirectional Association to Bidirectional
클래스의 양방향 연결을 단방향으로 전환 Change Bidirectional Association to Unidirectional
마법 숫자를 기호 상수로 전환 Replace Magic Number with Symbolic Constant
필드 캡슐화 Encapsulate Field
컬렉션 캡슐화 Encapsulate Collection
레코드를 데이터 클래스로 전환 Replace Record with Data Class
분류 부호를 클래스로 전환 Replace Type Code with Class
분류 부호를 하위클래스로 전환 Replace Type Code with Subclasses
분류 부호를 상태/전략 패턴으로 전환 Replace Type Code with State/Strategy
하위클래스를 필드로 전환 Replace Subclass with Fields

CHAPTER 09 조건문 간결화
조건문 쪼개기 Decompose Conditional
중복 조건식 통합 Consolidate Conditional Expression
조건문의 공통 실행 코드 빼내기 Consolidate Duplicate Conditional Fragments
제어 플래그 제거 Remove Control Flag
여러 겹의 조건문을 감시 절로 전환 Replace Nested Conditional with Guard Clauses
조건문을 재정의로 전환 Replace Conditional with Polymorphism
Null 검사를 널 객체에 위임 Introduce Null Object
어설션 넣기 Introduce Assertion

CHAPTER 10 메서드 호출 단순화
메서드명 변경 Rename Method
매개변수 추가 Add Parameter
매개변수 제거 Remove Parameter
상태 변경 메서드와 값 반환 메서드를 분리 Separate Query from Modifier
메서드를 매개변수로 전환 Parameterize Method
매개변수를 메서드로 전환 Replace Parameter with Explicit Methods
객체를 통째로 전달 Preserve Whole Object
매개변수 세트를 메서드로 전환 Replace Parameter with Method
매개변수 세트를 객체로 전환 Introduce Parameter Object
쓰기 메서드 제거 Remove Setting Method
메서드 은폐 Hide Method
생성자를 팩토리 메서드로 전환 Replace Constructor with Factory Method
하향 타입 변환을 캡슐화 Encapsulate Downcast
에러 부호를 예외 통지로 교체 Replace Error Code with Exception
예외 처리를 테스트로 교체 Replace Exception with Test

CHAPTER 11 일반화 처리
필드 상향 Pull Up Field
메서드 상향 Pull Up Method
생성자 내용 상향 Pull Up Constructor Body
메서드 하향 Push Down Method
필드 하향 Push Down Field
하위클래스 추출 Extract Subclass
상위클래스 추출 Extract Superclass
인터페이스 추출 Extract Interface
계층 병합 Collapse Hierarchy
템플릿 메서드 형성 Form Template Method
상속을 위임으로 전환 Replace Inheritance with Delegation
위임을 상속으로 전환 Replace Delegation with Inheritance

CHAPTER 12 복합 리팩토링
상속 구조 정리 Tease Apart Inheritance
절차 코드를 객체로 전환 Convert Procedural Design to Objects
도메인 로직을 표현과 분리 Separate Domain from Presentation
계층구조 추출 Extract Hierarchy

CHAPTER 13 리팩토링, 재사용, 현실성
개발자가 리팩토링을 꺼리는 이유
현실성 다시 검토하기
리팩토링 자료와 참고문헌
소프트웨어 재사용과 기술 변경이 미치는 영향
끝 인사
참고문헌

CHAPTER 14 리팩토링 도구
도구를 이용한 리팩토링
리팩토링 도구의 기술적 요건
리팩토링 도구의 실무적 요건
맺음말
[교보문고에서 제공한 정보입니다.]