reviews/Clean Code (16) 썸네일형 리스트형 08. 경계 유사한 경계 인터페이스를 사용할 때에는 여기저기 직접 넘기지 말고 캡슐화하여 사용하라. 클래스나 클래스 계열 밖으로 노출되지 않도록 한다. 학습 테스트 프로그램에서 사용하려는 방식대로 외부 API를 호출한다. 학습테스트의 장점 필요한 지식을 확보하는 손쉬운 방법이다. 새 버전이 나온다면 학습 테스트를 돌려 차이가 있는지 확인한다. 아직 존재하지 않는 코드를 사용하기 우리에게 필요한 경계 인터페이스가 무엇인지 알게되면 모르는 부분을 떼어 분리하여 그 부분의 구현을 나중으로 미룰 수 있다. 깨끗한 경계 경계에 위치하는 코드는 깔끔히 분리해야하며 기대치를 정의하는 테스트 케이스도 작성한다. 새로운 클래스로 경계를 감싸거나 ADAPTER 패턴을 사용한다. 소프트웨어 설계가 우수하다면 변경하는데 많은 투자와 재작.. 07. 오류 처리 오류 코드보다 예외를 사용하라 논리와 오류 처리 코드를 구분하기 위함 테스트 작성법 먼저 강제로 예외를 일으키는 테스트 케이스를 작성한 후 테스트를 통과하게 코드를 작성하는 방법이 권고됨 -> 자연스럽게 try 블록의 트랜잭션 범위부터 구현하게 되므로 범위 내에서 트랜잭션 본질을 유지하기 쉬워짐 미확인 예외를 사용하라 확인 예외가 필요한 경우도 있지만 남용한 경우 거치는 모든 단계에 확인 예외를 추가해줘야 하는 번거로움이 생길 수 있음 감싸기 기법을 사용하라 호출자를 고려해 예외 클래스를 정의하라. 특히 외부 API를 사용하는 경우 외부 API를 감싸면 외부 라이브러리와 프로그램 사이에서 의존성이 크게 줄어듦 테스트하기에도 수월해짐 Null을 반환하지 마라 Null을 반환하는 코드는 호출자에게 문제를 떠.. 06. 객체와 자료 구조 구현을 감추려면 추상화가 필요하다. 변수 사이에 함수라는 계층을 넣는다고 구현이 저절로 감춰지지는 않는다. 추상 인터페이스를 제공해 사용자가 구현을 모른 채 자료의 핵심을 조작할 수 있어야 진정한 의미의 클래스다. 절차적인 코드와 자료구조 vs 클래스와 객체 지향 기법 객체와 자료 구조는 근본적으로 양분된다. 절차적인 코드와 자료구조 기존 자료 구조를 변경하지 않으면서 새 함수를 추가하기 쉽다. 새로운 자료 구조를 추가하기 어렵다. (모든 함수를 고쳐야 함) => 새로운 자료 타입이 아니라 새로운 함수가 필요한 경우에 더 적합 클래스와 객체 지향 기법 기존 함수를 변경하지 않으면서 새 클래스를 추가하기 쉽다. 새로운 함수를 추가하기 어렵다. (모든 클래스를 고쳐야 함) => 새로운 함수가 아니라 새로운 .. 05. 형식 맞추기 코드 형식은 의사소통의 일환이다. 원활한 소통을 장려하는 코드 형식 적절한 행 길이를 유지하라. 소스 파일 첫 부분은 고차원 개념과 알고리즘을 성명하고 아래로 내려갈수록 의도를 세세하게 묘사한다. 생각의 사이에는 빈 행을 넣어 분리한다. 변수는 사용위치에 최대한 가까이 선언한다. *단, 인스턴스 변수는 클래스 맨 처음에 선언하며 C++의 경우 모든 인스턴스 변수를 클래스 마지막에 선언하는 가위 규칙을 적용함 세로 형식: 서로 밀접한 코드들은 가까이에 놓여야 한다. 종속함수. 한 함수에서 호출하는 다른 함수는 바로 그 아래에 정의되어 있어야 한다. 이렇게 표현하면 소스 코드 모듈이 고차원에서 저차원으로 자연스럽게 내려간다.가로 형식: ~120자가 적당하다. 공백의 사용 할당 연산자 앞뒤로 공백을 주어 왼쪽.. 04. 주석 한마디 "나쁜 코드에 주석을 달지 마라. 새로 짜라." - 브라이언 W. 커니핸, P.J. 플라우거 우리는 코드로 의도를 충분히 표현하지 못해서 주석을 사용한다. 주석은 거짓말을 한다. 프로그래머들이 주석을 유지보수하기 쉽지 않아 주석은 오래될수록 틀린 정보를 가질 가능성이 높다. 부정확한 주석은 더 이상 지킬 필요가 없는 규칙이나 지켜서는 안 되는 규칙을 명시한다. 코드만이 정확한 정보를 제공하는 유일한 출처다. 좋은 주석 저작권 정보와 소유권 정보 등의 법적인 주석 의도를 설명하는 주석 중요성을 강조하는 주석 결과를 경고하는 주석 //TODO 주석 Javadocs 책에는 안써있지만 개인적으로 사용하기 시작한 플랫폼의 버전이나 deprecated 등의 정보가 달려있을 때 유용했다. 나쁜 주석 독자와 제.. 03. 함수 한 줄 요약 함수를 짜는 것은 글짓기와 같아 초안에서 말을 다듬고 문장을 고치고 문단을 정리하라 1장에서 말했듯이 다음에 고쳐야지~하고 미루지 말고 바로바로 퇴고하며 고치자 ㅠ 함수는 한가지를 해야한다 의미 있는 이름으로 다른 함수를 추출할 수 있다면 한가지가 아님 플래그 인수가 들어간다면 한가지가 아님 중첩 구조가 생길만큼 함수가 커져선 안된다 함수의 이름 서술적인 이름을 사용하라 코드는 위에서 아래로 읽는다 예외처리해라 if의 조건문에서 명령을 표현식으로 사용하기보다는 예외처리를 해라 try... catch문은 추하므로 별도 함수로 뽑아내라 정상동작 action과 오류처리 동작을 분리하라 중복은 소프트웨어에서 모든 악의 근원이다. 02. 의미 있는 이름 의도를 분명히 하라 이름의 길이 의미가 분명한 경우 이름이 짧을수록 좋다 이름 길이는 범위 크기에 비례한다. 아주 작은 블럭의 로컬 변수는 짧게 지어도 괜찮다 i : for문 안에서 사용하는 인덱스 변수 축약을 피해라 product -> prd, project -> prj 이름에 넣지 말아야 할 것 자료형, 타입 addList, sumList, iEmployeeNumber, sEmployeeName info / data 같이 의미 없는 단어 이름을 정할 때 유의해야 할 것 흡사한 이름을 사용하지 말라 유사한 개념은 유사한 표기법을 사용하라 add, append, ... 검색하기 쉬운 이름을 사용하라 인터페이스와 구현 클래스가 있는 경우 인터페이스의 이름을 원형으로, 추가 정보는 구현 클래스의 이름에 붙인.. 01. 깨끗한 코드 최고의 문단 우리 모두는 자신이 짠 쓰레기 코드를 쳐다보며 나중에 손보겠다고 생각한 경험이 있다. 우리 모두는 대충 짠 프로그램이 돌아간다는 사실에 안도감을 느끼며 그래도 안 돌아가는 프로그램보다 돌아가는 쓰레기가 좋다고 스스로를 위로한 경험이 있다. 다시 돌아와 나중에 정리하겠다고 다짐했었다. 물론 그때 그 시절 우리는 르블랑의 법칙을 몰랐다. 나중은 결코 오지 않는다. '코드 감각'으로 좋은 코드와 나쁜 코드를 구분하고, 좋은 코드로 바꾸는 전략을 파악하고 좋은 방안을 선택할 수 있다. 타고나지 못했으면 투쟁해서 얻자. 새 코드를 짜면서 우리는 끊임없이 기존 코드를 읽는다. 읽기 쉬운 코드가 그만큼 중요하다. 이전 1 2 다음