티스토리 뷰
참조에 의한 호출 ( call by reference )
함수에 전달된 파라미터의 값이 함수 안에서 변경된 경우, 함수를 호출한 쪽에 영향을 미치는 것을 의미한다.
c의 경우 주소 연산자 &를 이용한 편법이었다. (call by address)
예제1) c - call by address / call by value
void Swap(int* i, int* j) { int t = *i; *i = *j; *j = t; } void main() { int i = 2, j = 3; Swap(&i, &j); cout << i << " " << j << endl; }
- Swap(&i, &j) 는 단지 i와 j의 주소를 전달할 뿐이다. 정말 i와 j의 값을 swap하기 위해서는 Swap()함수 내부에서 포인터 연산을 해야한다.
예제2) c++ - call by reference
void Swap(int& i, int& j) { int t = i; i = j; j = t; } void main() { int i = 2, j = 3; Swap(i, j); cout << i << " " << j << endl; }
- 컴파일러는 함수의 머리에 &가 명시되면 변수의 값을 전달하는 것이 아니라, 변수의 참조를 전달한다.
- Swap() 함수 내부를 보면 복잡한 포인터 연산이 없는 것을 확인할 수 있다.
- 핵심은 함수의 헤더에 &가 있다는 것이다.
C++에서는 값에 call by value, call by reference 모두 Swap(i, j);의 형식이다.
이는 가독성이 떨어지므로 복잡한 포인터 연산을 여러번 해야하는 경우를 제외하곤, 참조를 사용하지 않는 것이 좋다.
참조의 초기화
참조를 사용하려면 선언하면서 초기화되어야한다.
void main() { int i = 0; int& iAlias; iAlias = i; ++iAlias; }
위의 코드를 컴파일 하면 "reference isn't initialized" 라는 에러가 발생할 것이다.
iAlias = i; 이것은 단순한 대입문일 뿐 초기화가 아니기 때문이다.
int& iAlias = i;
위와 같이 선언과 동시에 초기화를 해주어야한다.
'programming language > c++' 카테고리의 다른 글
[c++] struct와 class의 차이 (0) | 2018.06.14 |
---|---|
[c++] freind 함수 (0) | 2018.06.12 |
[c++] StringCbCopy, StringCchCopy (1) | 2018.06.12 |
[c++] malloc/free, new/delete (0) | 2018.06.11 |
[C++] MultiByteToWideChar, WideCharToMultiByte 함수 (0) | 2018.06.07 |
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- 윈도우
- 알고리즘
- frameLayout
- OS
- handshake
- C++
- Android
- adapter
- layout
- 백준
- ConstraintLayout
- BOJ
- 이진탐색트리
- 퀵정렬
- DATABASE
- HTTP
- windows
- 안드로이드
- 스프링
- 정렬 알고리즘
- RelativeLayout
- 네트워크
- debug
- 스프링부트
- LinearLayout
- WinDbg
- 백준알고리즘
- C
- listview
- 운영체제
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
글 보관함