반응형


[ 1. 구성과 관리에 관한 이슈들 ]

1.작은 것에 연연하지 말라.
2.사소한 경고 메시지라도 무시하지 말라.
3.자동화된 빌드 시스템을 사용하라.
4.버전 컨트롤 시스템을 사용하라.
5.코드 리뷰에 시간을 투자하라.


[ 2. 디자인 스타일 ]

6.하나의 엔티티에는 하나의 역할만을 부여하자.
7.정확성, 간결성, 명확성을 먼저 생각하라.
8.적절한 규모 유지를 위해서는 ‘언제, 어떻게’ 를 아는 것이 중요하다.
9.이른 최적화를 피하라.
10.미리 최적화해두어야 할 부분도 있다.
11.전역 데이터와 공유 데이터를 최소화하라.
12.정보를 숨겨라.
13.안전한 공유를 위한 코딩의 시기와 방식을 결정하라.
14.자원은 개체가 가지게끔 하라. RAII 와 스마트 포인터를 활용하라.


[ 3. 코딩 스타일 ]

15.런타임 오류보다는 컴파일이나 링크 타임 오류가 낫다.
16.const 를 사용하라.
17.매크로 사용을 자제하라.
18.마법의 숫자는 쓰지 말라.
19.가능하면 로컬 변수를 선언하여 사용하라.
20.변수는 항상 초기화하여 사용하라.
21.너무 긴 함수와 많은 중첩 구조는 피하라.
22.컴파일 단위 사이의 초기화 의존성을 없애라.
23.정의의 의존성과 순환 의존성을 최소화하라.
24.헤더 파일은 충분히 완성된 형태로 만들어라.
25.내부 #include 가드를 사용하라. 외부 #include 가드를 써서는 안된다.


[ 4. 함수와 연산자 ]

26.값, ( 스마트 ) 포인터, 참조 중 적절한 방식으로 인자를 얻어라.
27.오버로딩된 연산자의 본래 의미를 유지하라.
28.표준적인 형식의 산술 및 할당 연산자를 사용하라.
29.++ 와 – 의 표준적인 형식과 접두 형식을 사용하라.
30.간접적인 타입 변환을 피하기 위해 오버로딩을 활용하라.
31.&&, ||, 그리고 콤마의 오버로딩은 피하라.
32.함수 인자의 처리 순서에 좌우되는 코드는 좋지 않다.


[ 5. 클래스 디자인과 상속성 ] 

33.만들고 있는 클래스가 무엇인지 확실히 하라.
34.최소화된 클래스를 사용하라.
35.상속성은 주의해서 사용하라.
36.기반 클래스로 디자인되지 않은 클래스로부터의 상속을 피하라.
37.추상 인터페이스를 활용하라.
38.상속의 정확한 의미를 이해하자. 재사용을 위해 상속하는 것은 아니지만, 재사용은 필요하다.
39.안전한 오버라이딩을 연습하라.
40.가상 함수는 비 public 으로, public 함수는 비가상으로 설정하라.
41.간접 변환을 피하라.
42.특징 없는 값의 집합( C 스타일의 struct ) 을 제외하고는 모든 데이터 멤버를 private 으로 유지하라.
43.내부의 것은 너무 노출시키지 말라.
44.pimpl을 적절히 활용하라.
45.비멤버 함수를 활용하라.
46.new 와 delete 는 항상 함께 제공하라.
47.특정한 클래스에 맞는 new 를 제공한다면 모든 표준 형식을 제공해야 한다.


[ 6. 생성과 파괴 그리고 복사 ]

48.멤버 변수의 정의와 선언은 같은 순서로 하라.
49.생성자 내에서 할당 대신 초기화를 사용하라.
50.생성자와 소멸자에서는 가상 함수의 호출을 피하라.
51.기반 클래스 소멸자는 public 과 가상 또는 protected 와 비가상으로 만들어라.
52.소멸자, 재할당 그리고 swap 은 절대 실패하지 않는다.
53.일관된 방식으로 복사하고 제거하라.
54.복사의 허용 여부는 명확하게 지정하라.
55.개체의 조각화를 피하라. 기반 클래스 내에서의 복사보다는 Clone을 활용하라.
56.정규형의 할당 방식을 사용하라.
57.필요하다면 실패가 없는 swap 을 활용하라.


[ 7. 네임스페이스와 모듈 ]

58.타입과 그의 비멤버 함수는 같은 네임스페이스 내에 넣어라.
59.특별히 함께 작동하게끔 의도된 경우가 아니라면 타입과 함수는 분리된 네임스페이스에 넣어라.
60.헤더 파일 내에 또는 #include 앞에 네임스페이스 using을 써서는 안된다.
61.서로 다른 모듈에서의 메모리 할당과 해지는 피하라.
62.헤더 파일 내에는 서로 연결된 엔티티를 정의해서는 안 된다.
63.예외가 모듈의 경계를 넘어 전달되는 것을 막아라.
64.모듈의 인터페이스 내에는 충분한 이식성을 갖춘 타입을 사용하라.


[ 8. 템플릿과 일반성 ]

65.정적, 동적인 다형성을 적절히 혼합하라.
66.계획적이고 직접적으로 커스텀화하라.
67.함수 템플릿은 특화해서는 안된다.
68.계획적이지 않고 일반적이지 않은 코드는 작성하지 말라.


[ 9. 오류와 예외의 처리 ]

69.내부적인 가정과 규칙을 확실하게 명시하라.
70.합리적인 오류 처리 방식을 수립하고, 엄격히 그 방식을 따르라.
71.어디까지가 오류인지 명확히 해두자.
72.오류로부터 안전한 코드를 디자인하고 작성하라.
73.오류 보고에는 예외를 활용하라.
74.예외를 발생시킬 때에는 값으로 하고, 잡아낼 때에는 참조로 하라.
75.목적에 맞게 오류를 보고하고, 제어하고, 변환하라.
76.예외 명세표는 만들 필요가 없다.


[ 10. STL: 컨테이너 ]

77.표준적으로 vector 를 사용하고, 그렇지 않다면 적절한 컨테이너를 선택하라.
78.배열 대신 vector 와 string 을 사용하라.
79.C++ API 가 아닌 다른 것들과의 데이터 교환을 위해서는 vector( 그리고 string::c_str ) 를 사용하라.
80.컨테이너에는 값과 스마트 포인터만을 저장하라.
81.요소의 추가에는 push_back 을 활용하라.
82.추가 작업에 있어 범위를 지정한 방식을 활용하라.
83.용량의 축소와 요소의 제거에 있어 적절한 방법을 사용하라.


[ 11. STL: 알고리즘 ]

84.검증된 STL 구현을 사용하라.
85.직접 작성한 루프보다는 알고리즘을 활용하라.
86.적절한 STL 검색 알고리즘을 사용하라.
87.적절한 STL 정렬 알고리즘을 사용하라.
88.술어를 순수한 함수로 만들어라.
89.알고리즘과 비교 인자에는 함수보다 함수 객체를 사용하라.
90.올바른 함수 객체를 만들자.


[ 12. 타입 안전 ]

91.타입의 변환을 피하고, 다형성을 활용하라.
92.표현 방식이 아닌 타입에 의존하라.
93.reinterpret_cast 사용을 자제하라.
94.포인터에 대한 static_Cast 사용은 피하라.
95.const 는 캐스팅하지 말자.
96.C 스타일의 캐스팅은 사용하지 말라.
97.POD( Plain old data ) 가 아닌 데이터를 memcpy 또는 memcmp 하지 말라.
98.union 사용을 주의하라.
99.가변 인자의 사용을 피하라.
100.올바르지 않은 객체와 안전하지 않은 함수는 사용하지 말라.
101.배열을 다형적으로 다루어서는 안된다.

< 출처: C++ 코딩의 정석: 101가지 규칙, 가이드라인, 좋은 습관들 >


반응형
Posted by tislqhf

블로그 이미지
개인적인 공부자료 정리하는 공간
tislqhf

태그목록

공지사항

Yesterday
Today
Total

달력

 « |  » 2025.1
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31

최근에 올라온 글

최근에 달린 댓글

최근에 받은 트랙백

글 보관함