항목 13: 자원 관리에는 객체가 그만!
스마트 포인터를 활용하여 별도로 객체 관리를 하지 않아도 되도록 만들자. std::auto_ptr, std::shared_ptr 을 활용
항목 14: 자원 관리 클래스의 복사 동작에 진지하게 고찰하자
RAII 객체를 복사할 때, 복사를 수행한 후 원래 객체가 해제가 되어 버리면 복사를 한 객체 쪽에서 해제 된 객체를 가질 가능성이 있다. 레퍼런스 카운터를 쓰거나 복사를 금지하는 방법을 활용하자
항목 15: 자원 관리 클래스에서 관리되는 자원은 외부에서 접근할 수 있도록 하자
캡슐화는 사용하기 편하고 실수를 줄이기 위해 만든 것이지, 반드시 데이터를 무조건 접근 금지하도록 하기 위한 것은 아니다. 암시적 변환이나 Get() 함수등을 통해 접근을 가능하도록 만들면 해당 자원에 대한 API 를 사용할 수 있을 것이다
항목 16: new 및 delete 를 사용할 때는 형태를 반드시 맞추자
delete 와 delete[] 의 쌍을 잘 맞추자. 잘못하면 정의되지 않은 동작이 발생한다.
항목 17: new 로 생성한 객체를 스마트 포인터에 저장하는 코드는 별도의 한 문장으로 만들자
shared_ptr 를 만들기 위해 shared_ptr( new Object() ) 와 같이 동적 할당을 할 경우에는, 해당 문장을 별도의 한 문장으로 만들도록 하자. 무슨 말이냐면 int val = SomeFunction( shared_ptr( new Object() ), getNumber() ) 와 같이 다른 동작을 함께하는 코드와 같이 넣지 말자는 말이다. c++ 컴파일러가 getNumber() 를 먼저 수행할지, shared_ptr 부분을 먼저 수행할지, Object() 부분을 먼저 수행할지 따로 정해진 사양이 없기 때문이다
'개발자의 길 > Effective C++' 카테고리의 다른 글
[Effective C++] Chapter 6 상속, 그리고 객체 지향 설계 (작성중) (0) | 2020.03.07 |
---|---|
[Effective C++] Chapter 5 구현 (0) | 2020.03.07 |
[Effective C++] Chapter 4 설계 및 선언 (0) | 2020.02.29 |
[Effective C++] Chapter 2 생성자, 소멸자 및 대입 연산자 (0) | 2019.03.24 |