일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- 반복자
- more effective c++
- virtual function
- 예외
- 언리얼
- 티스토리챌린지
- Effective c++
- implicit conversion
- 영화 리뷰
- c++
- 참조자
- 영화
- 게임
- 오블완
- resource management class
- 스마트 포인터
- 다형성
- operator new
- reference
- 함수 객체
- 메타테이블
- exception
- lua
- effective stl
- 상속
- UE4
- 암시적 변환
- Smart Pointer
- 비교 함수 객체
- effective modern c++
- Today
- Total
목록분류 전체보기 (204)
스토리텔링 개발자
항목 12 : 예외 발생이 매개변수 전달 혹은 가상함수 호출과 어떻게 다른지를 이해해자. 함수 매개변수와 예외발생 구문class Widget { ... };// 함수 매개변수void f1(Widget w);void f2(Widget& w);void f3(const Widget& w);void f4(Widget* pw);void f5(const Widget* pw);// 예외처리 구문catch(Widget w) ...catch(Widget& w) ...catch(const Widget& w) ...catch(Widget* w) ...catch(const Widget* w) ...문법상으론 다른 점을 찾을 수 없다. 유사점전달 방식값, 참조, 포인터 전달이 모두 가능하다. 차이점 프로그램 흐름함수..
항목 11 : 소멸자에서는 예외가 탈출하지 못하게 하자 소멸자가 호출되는 상황객체가 통상적인 조건에서 소멸되었을 때지역변수 객체가 유효범위(scope)를 벗어날 때객체가 직접 삭제(delete)될 때예외 처리 매커니즘에 의해 객체가 소멸되었을 때예외 전파(exception propagation) 과정의 일부분으로 스택 되감기가 진행될 때즉, 소멸자가 호출되었을 때 예외가 발생된 상태인지 아닌지 알 방도가 없다.실은 이제는 std::uncaught_exception을 통해서 예외가 스택 되감기(unwinding) 중인지 알아낼 수 있다. 예외가 소멸자를 빠져나가면 안되는 이유 1소멸자 내부에서 예외 발생 상태인지 구별할 방법이 없다.어떤 상황이든 예외가 발생된 상태라고 가정하고 소멸자를 방어적으로 ..
항목 10. 생성자에서는 리소스 누수가 일어나지 않게 하자. 생성자 설계 예제// 이미지 정보 클래스class Image{public: Image(const string& imageDataFileName); ...};// 오디오 정보 클래스class AudioClip{public: AudioClip(const string& audioDataFileName); ...};// 전화번호 클래스class PhoneNumber { ... };// 주소록에 들어가는 하나의 정보에 대한 클래스class BookEntry{public: BookEntry(const string& name, const string& address = "", co..
항목 9 : 리소스 누수를 피하는 방법의 정공은 소멸자이다. 지역 리소스에 대한 포인터지역 리소스(스택에서 생긴 리소스)를 조작할 때, 포인터는 부적절할 수 있다.소멸자가 불리지 않는 상황이 발생할 수 있기 때문이다.즉, 리소스 누수가 발생할 수 있다는 뜻이다.class ALA{public: virtual void processAdoption() = 0; ...};class Puppy : public ALA{public: virtual void processAdoption(); ...};class Kitten : public ALA{public: virtual void processAdoption(); ...};// s로부터 동물 정보를 읽어서// 적절한 타입의 객체를..
항목 8 : new와 delete의 의미를 정확히 구분하고 이해하자 ‘new 연산자’와 ‘operator new’의 차이string* ps = new string("Memory Management"); // new 연산자가 사용되었다.new 연산자C++에서 기본으로 제공한다.sizeof가 그런 것처럼, 동작 원리를 바꾸는 것이 불가능하다.동작 단계요청 타입의 객체를 담을 수 있는 크기의 메모리를 할당한다.(이 동작이 operator new 함수 호출로 동작된다.)객체의 생성자를 호출하여 할당된 메모리의 객체 초기화를 수행한다.operator new객체로 담을 메모리를 할당하는 방법이다.new 연산자는 필수적인 메모리 할당을 위해 operator new를 호출하게 되어 있다. operator new..
항목 7 : &&, ||, 혹은 , 연산자는 오버로딩 대상이 절대로 아니다 단축 평가(short-circuit)C와 마찬가지로 C++ 역시 복합적인 불린 표현식을 평가할 때 단축 평가 처리를 할 수 있다.즉, 표현식의 일부가 참, 거짓임이 판명되면, 그 이후의 표현식은 무시하고 평가를 중단한다.// 1.char* p;// 이 경우, p != 0 이 거짓으로 판명되면 strlen이 호출될 걱정을 할 필요가 없다.// 즉, null 포인터에 대한 strlen 호출이 되지 않음을 가정하고 작성한 코드이다.// null 포인터에 대한 strlen 호출은 미정의 사항이기 때문이다.if((p != 0) && (strlen(p) > 10)){ ... }// 2.int rangeCheck(int index){ ..
항목 6 : 증가 및 감소 연산자의 전위 / 후위 형태를 반드시 구분하자 ++, -- 연산자 오버로드 규칙의 필요성80년대 후반에는 전위, 후위 방식으로 호출하는 것을 구분할 방법이 없었다.그래서 해당 연산자의 전위 / 후위 형태를 오버로딩 할 수 있도록 스팩이 향상되었다.근데 오버로딩은 보통 매개변수의 타입에 따라 구분되는데?증감 연산자는 인자를 전혀 받지 않는다는 문제가 있다.그래서 아래의 규칙이 생겨났다. 증감 연산자의 오버로딩 규칙후위 형태는 int 타입의 인자를 받는다.증감 연산자가 후위로 호출될 때 컴파일러는 해당 인자로 0을 넘겨준다.전, 후위 형태는 서로 다른 타입을 반환한다.전위 형태참조자 타입을 리턴후위 형태const 객체 타입을 리턴class UPInt{public: UP..
항목 5. 사용자 정의 타입 변환 함수에 대한 주의를 놓지 말자 암시적 변환C처럼 C++ 역시 암시적 변환을 지원한다.예컨대 char -> int, short -> double 로 군소리 없이 변환시켜 준다.심지어 int -> short, double -> char 처럼 데이터 손상 여지가 있는 변환도 지원한다.raw 타입에 대해선 어쩔 수 없지만, 커스텀 타입에 대해서는 이 암시적 변환을 확실히 제어할 수 있다.암시적 타입 변환을 위해 컴파일러가 사용할 수 있는 함수를 제공하면 된다. 암시적 타입 변환 함수의 종류 1. 단일 인자 생성자(single-argument constructor)인자를 하나만 받아 호출하는 생성자를 말한다.하나의 매개변수만 받도록 선언.혹은 여러 매개변수이나, 처음 것을..