[c++] 생성자와 operator ()의 호출 차이에 대해 질문 있어요~
글쓴이: khnet / 작성시간: 일, 2012/04/29 - 10:57오전
F라는 class가 있을 때 이 class의 임시 객체에 대한 생성자 호출은 F()이고
리턴형과 인자가 모두 void인 void operator()()도 F() 이잖아요?
어떤 코드에서 F()라는 호출 구문이 있을 때 이 둘 중 어떤게 호출되는지 어떻게 구분하는 건가요?
그리고 이 둘을 구별해서 호출하는 방법이 있나요?
고수님들 답변 주시면 감사드리겠습니다
그리고 아래 코드는 생성자 -> 복사 생성자 순으로 불리는지
operator() -> 변환 생성자 순으로 불리는지 알아보려고 만든 코드인데
경고나 에러없이 컴파일은 되는데 실행해보면 아무것도 출력되지 않는데요...
그 이유도 알려주시면 감사드리겠습니당~
g++로 컴파일 했습니다.
#include <iostream>
using namespace std;
class F
{
public:
int a;
// 생성자
F() : a(0)
{
cout<<"F()"<<endl;
}
// 변환 생성자
F(int _a)
{
cout<<"F("<<_a<<")"<<endl;
}
// 복사 생성자
F(const F &_a)
{
cout<<"F(const F &_a)"<<endl;
}
// 함수 호출 연산자
int operator()()
{
a=1;
cout<<"operator()()"<<endl;
return a;
}
};
int main()
{
F A(F());
}Forums:


선언문에서의 ()가 operator()가 아닌
선언문에서의 ()가 operator()가 아닌 것은
operator=와 똑같이 생각하면 될겁니다.
선언문에서의 =는 operator=가 아니잖아요. ^^
gilgil.net
int main() { F A(F()); }이 것에서 F(A(F())는 객체의 선언이 아닌 함수의 선언으로 컴파일되는 것 같군요. 마치 아래와 같이 말이죠.
int main() { int test(void); }main 함수 위에서 F(A(F)) 의 body를 정의해 보면 컴파일 warning이 없어 지는 것을 확인할 수 있습니다.
F A(F()) { cout << "oops" << endl; return *((F*)NULL); } int main() { F A(F()); }www.gilgil.net
리턴형과 인자가 모두 void인 void
리턴형과 인자가 모두 void인 void operator()()도 F() 이잖아요?
-> 아니오. F()()입니다.
댓글 달기