목록Categories (1110)
KoreanFoodie's Study
C++ 프로그래머의 필독서이자 바이블인, 스콧 마이어스의 Modern Effective C++ 를 읽고 기억할 내용을 요약하고 있습니다. 꼭 읽어보시길 추천드립니다! 항목 15 : 자원 관리 클래스에서 관리되는 자원은 외부에서 접근할 수 있도록 하자 핵심 : 1. 실제 자원을 직접 접근해야 하는 기존 API 들도 많기 때문에, RAII 클래스를 만들 때는 그 클래스가 관리하는 자원을 얻을 수 있는 방법을 열어 주어야 한다. 2. 자원 접근은 명시적 변환 혹은 암시적 변환을 통해 가능하다. 안전성만 따지면 명시적 변환이 대체적으로 더 낫지만, 고객 편의성을 놓고 보면 암시적 변환이 괜찮다. 다음의 경우처럼, RAII 클래스의 객체를 그 객제가 감싸고 있는 실제 자원으로 변환해야 하는 경우가 종종 생긴다. ..
C++ 프로그래머의 필독서이자 바이블인, 스콧 마이어스의 Modern Effective C++ 를 읽고 기억할 내용을 요약하고 있습니다. 꼭 읽어보시길 추천드립니다! 항목 14 : 자원 관리 클래스의 복사 동작에 대해 진지하게 고찰하자 핵심 : 1. RAII 객체의 복사는 그 객체가 관리하는 자원의 복사 문제를 안고 가기 때문에, 그 자원을 어떻게 복사하느냐에 따라 RAII 객체의 복사 동작이 결정된다. 2. RAII 클래스에 구현하는 일반적인 복사 동작은 복사를 금지하거나 참조 카운팅을 해 주는 선으로 마무리하는 것이다. 하지만 이 외의 방법들도 가능하다! 우리가 직접 RAII 클래스를 만들어야 하는 다음과 같은 상황이 생겼다고 가정하자. class Lock { public: explicit Lock(..
C++ 프로그래머의 필독서이자 바이블인, 스콧 마이어스의 Modern Effective C++ 를 읽고 기억할 내용을 요약하고 있습니다. 꼭 읽어보시길 추천드립니다! 항목 13 : 자원 관리에는 객체가 그만! 핵심 : 1. 자원 누출을 막기 위해, 생성자 안에서 자원을 획득하고 소멸자에서 그것을 해제하는 RAII 객체를 사용하자 2. 일반적으로 널리 쓰이는 RAII 클래스는 shared_ptr 그리고 auto_ptr 이다. 이 둘 가운데 shared_ptr 이 복사 시의 동작이 직관적이기 때문에 대개 더 좋다. 반면, auto_ptr 은 복사되는 객체(원본 객체) 를 null 로 만들어 버린다. -> auto_ptr 은 C++ 11 이후로 쓸 수 없게 됨! 대신 unique_ptr 를 사용한다 스마트 포..
C++ 프로그래머의 필독서이자 바이블인, 스콧 마이어스의 Modern Effective C++ 를 읽고 기억할 내용을 요약하고 있습니다. 꼭 읽어보시길 추천드립니다! 항목 12 : 객체의 모든 부분을 빠짐없이 복사하자 핵심 : 1. 객체 복사 함수는 주어진 객체의 모든 데이터 멤버 및 모든 클래스 부분을 빠뜨리지 말고 복사해야 한다. 2. 클래스의 복사 함수 두 개를 구현할 때, 한 쪽을 이용해서 다른 쪽을 구현하려는 시도는 절대로 하지 말자. 그 대신, 공통된 동작을 제 3의 함수에다 분리해 놓고 양쪽에서 이것을 호출하게 만들어서 해결하자. 복사 생성자와 복사 대입 연산자를 통틀어 객체 복사 함수(copying function) 이라고 부른다. 그런데 컴파일러가 이들을 기본으로 만들다 보니, 사용자가 ..
C++ 프로그래머의 필독서이자 바이블인, 스콧 마이어스의 Modern Effective C++ 를 읽고 기억할 내용을 요약하고 있습니다. 꼭 읽어보시길 추천드립니다! 항목 11 : operator= 에서는 자기대입에 대한 처리가 빠지지 않도록 하자 핵심 : 1. operator= 를 구현할 때, 어떤 객체가 그 자신에 대입되는 경우를 제대로 처리하도록 만들자. 원본 객체와 복사대상 객체의 주소를 비교해도 되고, 문장의 순서를 적절히 조정할 수도 있으며, 복사 후 맞바꾸기 기법을 써도 된다. 2. 두 개 이상의 객체에 대해 동작하는 함수가 있다면, 이 함수에 넘겨지는 객체들이 사실 같은 객체인 경우에 정확하게 동작하는지 확인하자. 이런 코드는 사실 적법한(legal) 코드이다. class Widget{ ...
C++ 프로그래머의 필독서이자 바이블인, 스콧 마이어스의 Modern Effective C++ 를 읽고 기억할 내용을 요약하고 있습니다. 꼭 읽어보시길 추천드립니다! 항목 10 : 대입 연산자는 *this 의 참조자를 반환하게 하자 핵심 : 대입 연산자는 *this 의 참조자를 반환하도록 만들어라 C++ 의 대입 연산은 여러 개가 사슬처럼 엮일 수 있다. int x, y, z; // 대입은 우측 연관(right-associative)이다. x = y = z = 15; // 따라서 위 식은 실제로 아래와 같다 x = (y = (z = 15))); 대입 연산이 사슬처럼 엮이려면 대입 연산자가 좌변 인자에 대한 참조자를 반환하도록 구현하는 것이 좋다(일종의 관례[convention] 이다). 이는 += , -..
C++ 프로그래머의 필독서이자 바이블인, 스콧 마이어스의 Modern Effective C++ 를 읽고 기억할 내용을 요약하고 있습니다. 꼭 읽어보시길 추천드립니다! 항목 9 : 객체 생성 및 소멸 과정 중에는 절대로 가상 함수를 호출하지 말자 핵심 : 생성자 및 소멸자 안에서 가상 함수를 호출하지 말자! 가상 함수라고 해도, 지금 실행 중인 생성자나 소멸자에 해당되는 클래스의 파생 클래스 쪽으로는 내려가지 않는다! 객체 생성 및 소멸 과정 중에는 가상 함수를 호출하면 절대로 안 된다! 예시를 보자. // 모든 거래에 대한 기본 클래스 class Transaction { public: Transaction(); // 타입에 따라 달라지는 로그 기록을 만든다 virtual void logTransactio..
C++ 프로그래머의 필독서이자 바이블인, 스콧 마이어스의 Modern Effective C++ 를 읽고 기억할 내용을 요약하고 있습니다. 꼭 읽어보시길 추천드립니다! 항목 8 : 예외가 소멸자를 떠나지 못하도록 붙들어 놓자 핵심 : 1. 소멸자에서는 예외가 빠져나가면 안 된다. 만약 소멸자 안에서 호출된 함수가 예외를 던질 가능성이 있다면, 어떤 예외이든지 소멸자에서 모두 받아낸 후에 삼켜 버리든지 프로그램을 끝내든지 해야 한다. 2. 어떤 클래스의 연산이 진행되다가 던진 예외에 대해 사용자가 반응해야 할 필요가 있다면, 해당 연산을 제공하는 함수는 반드시 보통의 함수(즉, 소멸자가 아닌 함수) 이어야 한다. 다음과 같은 예시를 보자. class Widget { public: ... // 이 함수로부터 ..
C++ 프로그래머의 필독서이자 바이블인, 스콧 마이어스의 Modern Effective C++ 를 읽고 기억할 내용을 요약하고 있습니다. 꼭 읽어보시길 추천드립니다! 항목 7 : 다형성을 가진 기본 클래스에서는 소멸자를 반드시 가상 소멸자로 선언하자 핵심 : 1. 다형성을 가진 기본 클래스에는 반드시 가상 소멸자를 선언해야 한다. 즉, 어떤 클래스가 가상 함수를 하나라도 갖고 있으면, 이 클래스의 소멸자도 가상 소멸자이어야 한다. 2. 기본 클래스로 설계되지 않았거나 다형성을 갖도록 설계되지 않은 클래스에는 가상소멸자를 선언하지 말아야 한다. 다음과 같은 TimeKeeper 클래스를 만들고, 팩토리 메서드 패턴으로 파생 클래스의 타입에 맞는 객체를 리턴한다고 가정하자. class TimeKeeper { ..
C++ 프로그래머의 필독서이자 바이블인, 스콧 마이어스의 Modern Effective C++ 를 읽고 기억할 내용을 요약하고 있습니다. 꼭 읽어보시길 추천드립니다! 항목 6 : 컴파일러가 만들어낸 함수가 필요 없으면 확실히 이들의 사용을 금해 버리자 핵심 : 컴파일러에서 자동으로 제공하는 기능을 허용치 않으려면, 대응되는 멤버 함수를 private 으로 선언한 후에 구현은 하지 않은 채로 두자. Uncopyable 과 비슷한 기본 클래스를 쓰는 것도 한 방법이다. 우리가 부동산을 판매하는 프로그램을 만들게 되었는데, 각 자산은 세상에서 하나밖에 없다는 것을 적용해 달라고 요청했다고 가정해 보자. 즉, 다음과 같은 코드는 컴파일이 되면 안된다는 뜻이다! class HomeForSale {...}; .....
