Alc*_*ott 3 c++ method-resolution-order
在C/C++中,当且仅当被调用函数对调用者可见时,调用函数才能调用被调用函数,这意味着被调用者的定义应该在它被使用之前完成,否则使用forward-declaration.
这是我的问题,
class A
{
public:
void foo()
{
bar();
}
void bar()
{
//...
}
};
int main()
{
A a;
a.foo();
}
Run Code Online (Sandbox Code Playgroud)
上面的代码可以正常工作.但foo电话bar和我没有把bar的定义之前foo或前瞻性声明bar,怎么可能调用bar的foo工作?编译器怎么能找到bar?
该语言表示成员函数声明的范围是整个类(松散地),所以这很好.
实际发生的是,在尝试分析内联函数的主体之前,编译器会等到类定义的结尾(实际上,最外层的封闭类定义的结尾).
所以它只查看课程bar结束时的调用,到那时它已经看到了它的声明,一切都很顺利.
| 归档时间: |
|
| 查看次数: |
403 次 |
| 最近记录: |