글
1. 2장을 시작하기 앞서서...
1) 아래의 차이점은?
- const int n = 10; <-- int 형 변수 n의 데이터 상수화, n 값은 변경 불가
- const int *n; <-- int 형 포인트 변수 n의 데이터 상수화
- int* const n; <-- int 형 포인트 변수 n에 대한 포인트 상수화
- const int* const n; <-- 바로 위의 2가지 모두
2) 스택과 힙의 필요성
- (프로그램 코드가 들어가는 text 영역은 제외하고,)
전역 변수와 static 변수등은 data 영역에 프로그램 시작시에 할당이 된다.
하지만 지역변수와 매개변수등등 컴파일 타임에 크기가 결정되는 변수들은 stack 영역에 할당이 된다.
함수 호출 시 할당되고 함수 종료시 할당이 해제되는 과정이 자동으로 반복된다
문제가 되는 녀석들은 컴파일 타임에 크기가 결정되지 않는 변수들인데
이러한 변수들은 프로그래머가 일일이 생성시 메모리 할당을 해줘야하고 종료시 해제시켜줘야 한다.
프로그래머가 malloc아니 free 등으로 이런 변수들을 할당/해제하는 메모리 영역이 heap 영역이다.
3) malloc/free
위에서 설명한대로 컴파일 타임이 아니라 런타임에 크기가 결정되는 변수들은 heap 영역에
동적 할당 및 해제 작업을 해줘야 한다... 그게 바로 malloc/free이다... 당근 free에 각별한 신경을 써야한다.
2. bool 자료형
- C++에는 bool 자료형이 별도로 존재하므로 이를 잘 이용하자
3. 레퍼런스에 들어가기 앞서서 call by value와 call by reference에 관해서
- 처음 C를 배울 때 call by value와 포인터를 이용한 call by reference 함수 호출에 관해 배웠었다
주요한 차이점은 포인터를 이용한 call by reference의 경우, 매개 변수 조작이 함수가 종료되도 남아있고
call by value의 경우에는 그렇지 않다는 것과 call by value가 메모리를 많이 잡아 먹는다는 것이였다...
이 얘기는 2장에서 설명하는 call by reference에서도 동일하게 적용된다.
4. 레퍼런스 (reference)
1) 의미
- 이름을 지니는 공간에 별명을 붙여주는 행위, 즉 메모리 공간에 2개 이상의 이름을 붙이는 행위
- 위의 의미에서도 알수 있듯이 이름이 존재하지 않는 상수 따위에겐 reference를 사용할 수 없다
2) 형태
- int &ref = val;
3) 레퍼런스에 의한 call by reference
- 위의 경우처럼 레퍼런스를 이용한 call by reference의 경우, 포인터를 이용해 함수를 구현하지 않으므로
프로그래밍 상의 오류를 줄일 수 있고 가독성이 좋아 유지 보수가 편할 수 있다
- 단점은, 포인터에 의한 call by reference 처럼 함수내에서 변수에 잘못된 연산을 했을 때
이 결과가 함수를 종료된 이후에도 영향을 끼쳐 전체 프로그램에 문제를 야기할 수 있다는 것과
함수 호출만봐서는 call by reference인지 call by value인지 알수가 없다는 것이다
- 위의 잘못된 연산과 관해서는 const 키워드로 매개변수를 상수화 시켜 해결이 가능하므로
필요한 경우에 따라 reference를 잘 이용하면 좋은 결과가 있을 수 있다
4) 레퍼런스를 return 하는 함수의 경우
- 절대 지역변수를 레퍼런스로 return 해서는 안된다
- 위의 경우, 실행을 해보면 n, val, ref는 모두 같은 주소를 가지고(같은 주소에 붙은 이름이며)
결과값도 예상한 것처럼 정확하게 나오는 것을 확인 가능하다
- 이제 위와 같이 변경해서 실행해보면 결과값이 이전과 다르게 나오는 것이 확인 가능하다
- 단지 매개변수를 reference에서 그냥 call by value로 변경했을 뿐인데 이유는 무엇일까?
위에서 말한 것처럼 절대 지역변수를 레퍼런스로 return 해서는 안되기 때문이다
- 2가지 모두 매개변수를 reference 타입으로 return하지만,
첫번째 경우는 reference로 매개변수를 받았기 때문에 함수가 종료되어도 매개변수 val 라는 레퍼런스만
없어지는 것이지 그 메모리 공간까지 사라지는 것은 아니기 때문에 이상이 없는 것이고
두번째 경우는 함수 호출시 val이라는 새로운 메모리를 stack에 할당받아 거기에 같은 복사하여 사용하고
ref는 val를 레퍼런스하는데 함수 종료시 val은 할당해제가 되고 컴파일러에 의해서 거기에 다른 변수가
할당이 될수 있으므로 ref로 해당 메모리를 참조하는 시점에 그 데이터 값은 보장할 수가 없게 된다.
- 쉬운 내용인데 설명만 길어지고 어려워져서... -_-;;;; 암튼 지역변수는 절대 레퍼런스로 리턴해선 안되고,
이렇게 하는것은 포인터 변수 생성만 하고 초기화나 할당없이 참조하는것과 똑같다고 보면 된다.
5. new와 delete
1) 일단 아래처럼만 알아두자
- int *val = new int;
- int *arr = new int[size];
- delete val;
- delete []arr;
1) 아래의 차이점은?
- const int n = 10; <-- int 형 변수 n의 데이터 상수화, n 값은 변경 불가
- const int *n; <-- int 형 포인트 변수 n의 데이터 상수화
- int* const n; <-- int 형 포인트 변수 n에 대한 포인트 상수화
- const int* const n; <-- 바로 위의 2가지 모두
2) 스택과 힙의 필요성
- (프로그램 코드가 들어가는 text 영역은 제외하고,)
전역 변수와 static 변수등은 data 영역에 프로그램 시작시에 할당이 된다.
하지만 지역변수와 매개변수등등 컴파일 타임에 크기가 결정되는 변수들은 stack 영역에 할당이 된다.
함수 호출 시 할당되고 함수 종료시 할당이 해제되는 과정이 자동으로 반복된다
문제가 되는 녀석들은 컴파일 타임에 크기가 결정되지 않는 변수들인데
이러한 변수들은 프로그래머가 일일이 생성시 메모리 할당을 해줘야하고 종료시 해제시켜줘야 한다.
프로그래머가 malloc아니 free 등으로 이런 변수들을 할당/해제하는 메모리 영역이 heap 영역이다.
3) malloc/free
위에서 설명한대로 컴파일 타임이 아니라 런타임에 크기가 결정되는 변수들은 heap 영역에
동적 할당 및 해제 작업을 해줘야 한다... 그게 바로 malloc/free이다... 당근 free에 각별한 신경을 써야한다.
2. bool 자료형
- C++에는 bool 자료형이 별도로 존재하므로 이를 잘 이용하자
3. 레퍼런스에 들어가기 앞서서 call by value와 call by reference에 관해서
- 처음 C를 배울 때 call by value와 포인터를 이용한 call by reference 함수 호출에 관해 배웠었다
주요한 차이점은 포인터를 이용한 call by reference의 경우, 매개 변수 조작이 함수가 종료되도 남아있고
call by value의 경우에는 그렇지 않다는 것과 call by value가 메모리를 많이 잡아 먹는다는 것이였다...
이 얘기는 2장에서 설명하는 call by reference에서도 동일하게 적용된다.
4. 레퍼런스 (reference)
1) 의미
- 이름을 지니는 공간에 별명을 붙여주는 행위, 즉 메모리 공간에 2개 이상의 이름을 붙이는 행위
- 위의 의미에서도 알수 있듯이 이름이 존재하지 않는 상수 따위에겐 reference를 사용할 수 없다
2) 형태
- int &ref = val;
3) 레퍼런스에 의한 call by reference
- 위의 경우처럼 레퍼런스를 이용한 call by reference의 경우, 포인터를 이용해 함수를 구현하지 않으므로
프로그래밍 상의 오류를 줄일 수 있고 가독성이 좋아 유지 보수가 편할 수 있다
- 단점은, 포인터에 의한 call by reference 처럼 함수내에서 변수에 잘못된 연산을 했을 때
이 결과가 함수를 종료된 이후에도 영향을 끼쳐 전체 프로그램에 문제를 야기할 수 있다는 것과
함수 호출만봐서는 call by reference인지 call by value인지 알수가 없다는 것이다
- 위의 잘못된 연산과 관해서는 const 키워드로 매개변수를 상수화 시켜 해결이 가능하므로
필요한 경우에 따라 reference를 잘 이용하면 좋은 결과가 있을 수 있다
4) 레퍼런스를 return 하는 함수의 경우
- 절대 지역변수를 레퍼런스로 return 해서는 안된다
- 위의 경우, 실행을 해보면 n, val, ref는 모두 같은 주소를 가지고(같은 주소에 붙은 이름이며)
결과값도 예상한 것처럼 정확하게 나오는 것을 확인 가능하다
- 이제 위와 같이 변경해서 실행해보면 결과값이 이전과 다르게 나오는 것이 확인 가능하다
- 단지 매개변수를 reference에서 그냥 call by value로 변경했을 뿐인데 이유는 무엇일까?
위에서 말한 것처럼 절대 지역변수를 레퍼런스로 return 해서는 안되기 때문이다
- 2가지 모두 매개변수를 reference 타입으로 return하지만,
첫번째 경우는 reference로 매개변수를 받았기 때문에 함수가 종료되어도 매개변수 val 라는 레퍼런스만
없어지는 것이지 그 메모리 공간까지 사라지는 것은 아니기 때문에 이상이 없는 것이고
두번째 경우는 함수 호출시 val이라는 새로운 메모리를 stack에 할당받아 거기에 같은 복사하여 사용하고
ref는 val를 레퍼런스하는데 함수 종료시 val은 할당해제가 되고 컴파일러에 의해서 거기에 다른 변수가
할당이 될수 있으므로 ref로 해당 메모리를 참조하는 시점에 그 데이터 값은 보장할 수가 없게 된다.
- 쉬운 내용인데 설명만 길어지고 어려워져서... -_-;;;; 암튼 지역변수는 절대 레퍼런스로 리턴해선 안되고,
이렇게 하는것은 포인터 변수 생성만 하고 초기화나 할당없이 참조하는것과 똑같다고 보면 된다.
5. new와 delete
1) 일단 아래처럼만 알아두자
- int *val = new int;
- int *arr = new int[size];
- delete val;
- delete []arr;
'C/C++' 카테고리의 다른 글
[열혈강의 C++] 1장 C 기반의 C++ 1 (0) | 2008.08.20 |
---|---|
this 포인터 (0) | 2008.08.13 |
[스크랩] ioctl() (0) | 2008.08.11 |
[스크랩] Mutex를 이용한 쓰레드 동기화 - 조인시 위키 (0) | 2008.08.01 |
[스크랩] 쓰레드는 무엇이며, 왜 이용하는가 - 조인시 위키 (0) | 2008.08.01 |
RECENT COMMENT