1. 下面程序输出是多少?
Union U { char str[ 2 ]; short int num;}; int main() { U u; u.str[ 0 ] = 10 ; u.str[ 1 ] = 1 ; cout << u.num << endl; system( " PAUSE " ); return 0 ;}
结果为266。对于整数类型,都是低字节存低位,高字节存高位,因此低位是10,高位是1,结果=1*256+10=266。
2. 下面不同变量之间地址大小关系
class Test { public : int m; int n;}; int main() { int a; char b; int c[ 10 ]; Test t; cout << (size_t) & a << endl; cout << (size_t) & b << endl; cout << (size_t) & c << endl; cout << (size_t) & t << endl; cout << (size_t) & t.m << endl; cout << (size_t) & t.n << endl; system( " PAUSE " ); return 0 ;}
(size_t)&a > (size_t)&b > (size_t)&c > (size_t)&t.n > (size_t)&t.m = (size_t)t
2293612 > 2293611 > 2293552 > 2293548 > 2293544 = 2293544 a、b、c、t都是局部变量,在栈上存储,栈是从高地址到低地址,因此地址逐渐减小。结构体内部,先定义的地址小,后定义的地址大,这与类内的成员,数组总的元素,都是类似的。 此外,值得注意的是(size_t)&a-(size_t)&b=1,刚好是1个字节,即b的大小。(size_t)&b-(size_t)&c=59,这是因为首先需要字节对齐,补3个字节,从2293611,补到2293608,从2293607到2293552剩下的44个字节是数组占用,注意数组只有10个元素是40个字节,还有4个字节应该是数组名占用的,把数组名看作一个指针?或者是数组名本身包含数组长度的信息,具体情况不是很清楚,不过int a[10]占用的空间是44个字节,而10个int类型的变量占用40个字节。t的字节分配很简单,没有什么了。 总的来说,具体的地址,需要考虑“栈的高地址到低地址”和“字节对齐”以及“数组”这样的特殊情况等等。3. 总结
整数类型内部:低地址存储低位,高地址存储高位。 局部变量:先定义的高地址,后定义的低地址。 类,结构体,数组:先定义的低地址,后定义的高地址。 数组实际占用的空间,要比元素大,感觉上像是给数组名本身一个“指针类型”的空间,即4个字节。