C++ 에서 함수의 매개변수를 어떤 타입을 쓰는 것이 가장 좋을까요?
글쓴이: oruddk / 작성시간: 화, 2006/10/17 - 11:18오전
C++ 언어를 이용해서 프로그램을 만들고 있습니다.
각각의 함수의 매개변수를 어떤식으로 쓰는 것이 가장 프로그램을 최적화 시키는 방법인지 궁금합니다.
함수를 만들때 입력용 매개변수에는 포인터와 레퍼런스를 매개변수로 사용하는 방법 중에 어느것이 좋을까요?
또는 string 과 integer 같은 값을 함수의 매개변수로 사용할때 레퍼런스로 사용하는 방법과 변수를 이용하는 방법중 어느것이 프로그램을 더 효과적일지 궁금합니다. ^^
Forums:
그거야..
그때 그때 상황에 따라서 다르지요.
--------------------
생이 바람과 같고나..
바람과 같이
포인터를 쓰든
포인터를 쓰든 레퍼런스를 쓰든 둘간의 성능차는 없습니다.
단순히 개인취향인데요.. 저같은 경우에는 입력용은 레퍼런스로..
출력용으로는 포인터를 사용합니다.
-------------------------------------------------------------------------------
It's better to appear stupid and ask question than to be silent and remain stupid.
-------------------------------------------------------------------------------
It's better to appear stupid and ask question than to be silent and remain stupid.
C++ 에서 함수의 매개변수 타입
> 입력용 매개변수에는 포인터와 레퍼런스를 매개변수로 사용하는 방법 중에 어느것이 좋을까요
포인터와 레퍼런스 간의 성능 차이는 없겠지만, 포인터의 경우는 NULL 포인터가 넘어올 수 있으므로, 그에 대한 체크가 필요할 것이고요, 이에 비해 레퍼런스의 경우는 반드시 존재하는 개체가 넘어오게 되므로 바로 쓸 수 있는 차이가 있겠네요.
> string 과 integer 같은 값을 함수의 매개변수로 사용할때 레퍼런스로 사용하는 방법과 변수를 이용하는 방법중 어느것이 프로그램을 더 효과적일지 궁금합니다.
int 같은 built-in type 변수는 call by value로 넘기는 것과 포인터 및 레퍼런스로 넘기는 것이 별 차이가 없을 것이기 때문에 넘기는 인자의 원본이 변경되어야 하는 지의 여부를 가지고 int나 int*/int& 중 선택하면 될 것 같습니다. (포인터냐 레퍼런스냐는 위의 내용을 참고)
string의 경우는, 인자의 원본을 수정해야 하는 경우가 아니라면, const string& 로 넘기는 것이 불필요한 복사가 안 일어나면서, char* 까지 한번에 처리할 수 있으므로 좋을 것 같습니다. (물론 char* 포인터를 인자로 주고 호출하면 임시 객체가 생성될 것이므로, 이에 대한 성능 저하가 맘에 걸린다면 const char* 또는 char* 를 받는 함수도 오버로딩해서 제공하면 되겠지요)
(참고) 이런 내용은 Scott Meyers의 Effective C++/More Effective C++ 책에 잘 나와 있습니다.
포인터와 레퍼런스
포인터와 레퍼런스 간의 성능 차이는 없겠지만, 포인터의 경우는 NULL 포인터가 넘어올 수 있으므로, 그에 대한 체크가 필요할 것이고요, 이에 비해 레퍼런스의 경우는 반드시 존재하는 개체가 넘어오게 되므로 바로 쓸 수 있는 차이가 있겠네요.
-> 꼭 그렇지는 않습니다..
-------------------------------------------------------------------------------
It's better to appear stupid and ask question than to be silent and remain stupid.
-------------------------------------------------------------------------------
It's better to appear stupid and ask question than to be silent and remain stupid.
헉...
그럴... 수도... 있네요... -.-;
댓글 달기