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删掉以后,整个程序将会报错。

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。