Inside the C++ Object Model: The binding of data member
本节提到了typedef的作用域以及解析方式的问题,有以下代码段:
1 #include <iostream> 2 3 using namespace std; 4 5 typedef int length; 6 7 class X { 8 public: 9 length getVal() { 10 cout << sizeof(_val) << endl; 11 return _val; 12 }; 13 void setVal(length val) { 14 cout << sizeof(val) << sizeof(_val) << endl; 15 _val = val; 16 }; 17 private: 18 typedef double length; 19 length _val; 20 }; 21 22 int main(int argc, char* argv[]) { 23 X x; 24 x.setVal(3); 25 x.getVal(); 26 return 0; 27 }
其输出结果为:48和8.
在setVal函数中,参数部分的length被解析成了全局定义的typedef int length,而函数体中的length被解析成了class X里面定义的typedef double length。
由此得出的结论为,setVal参数部分的变量类型绑定是根据已经出现过的类型定义来做的,而函数体中的变量的类型绑定则是需要等整个class都分析完以后才开始执行绑定的。
顺便,如果将第5行的typedef int length删掉以后,整个程序将会报错。
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。