我的观点,您的建议!如有问题,敬请留言!
全部博文(16)
分类: C/C++
2013-05-13 21:00:23
1.在数组中比如int a[5],注意 a+1 和 &a + 1的不同之处,虽然a和&a的大小相同,但索表示的意义不同,也就是他们的基类型字节数不同, a+ 1所表示的a[1]这个值,但&a+1所表示的是a[5](溢出),&a是a数组存储区的首地址,当&a +1时,相当于加了一个int[5]类型大小的空间,int *p =(int *) (&a+1), 打印 p-1得到的是a[4]的值,c语言是一个强类型的语言,因为p是一个指向 int 型的指针,所以p-1就、会减4个字节,也就是一个int空间大小,使的p从a[5]地址处,降到a[4]处。
2. 比如int a = 3; 打印&a["welcome!"]会显示,"come",因为,数组元素中的[ ]是变址运算符,相当于*( + ),a["welcome"]相当于*( 3+"welcome" ),而"welcome"是一个字符串,它加3就像当于取它的第4个字符‘c',而取地址&是为了打印'l'后的字符串。
3. double a[2], *p, *q; p = a; q = p+1; 这里的加1是加的一个double类型的字节的空间,p,q能访问一个double类型空间大小的数,因此p和p+1会相差8字节(不同编译器会有不同),而int *a 和 a +1会相差4字节等等;而(int)q - (int)p 是多大?是double型字节数,因为数组是连续的空间,(int)q - (int)p就是将q,p的地址 值 转成int型相减,大小就是double型字节数;而(int *)q - (int *)p又会是多少?是2,(这里按double 8字节,int 4字节算的),这是为什么呢?这样来看,double *p 能访问的是一个8字节的数,而int *p能访问的是一个4字节的数,而将double *p强制转换成int * ,那编译器会把原来的8字节访问空间分成2个4字节空间,所以(int *)q - (int *)p等于2;
4.sizeof 运算符一般是不会对所要查询的表达式进行计算。比如 int i = 3; sizeof(i++), printf("%d\n",i); 显示的不是4而还是3, sizeof()还能根据表达式的类型或函数的返回类型进行进行查询。比如int a = 3; double b = 3; sizeof(a+b),显示的是8 ; char f() ,这是一个返回值为char的函数。sizeof(f())显示的是1. sizeof 是可以不加括号的,
但在这种情况下必须加(), 即sizeof(int); sizeof int .这样写是错的。
5. 一般情况下 int 是4个字节,现在假设有这样一个int 型的ox112a3e4f整数,它占满的4个字节。现在要将这个
整数的高低字节中的数进行交换,最后得到的是ox4f3e2a11;这里的要点就是怎样获取这4个字节中的数?其实可以个这样定义: union A{ int i ; char b[4];}a; 然后对i赋值,用b数组来获取个字节中的数。。。。。
6. 如果有这样的一个数组 int a[3][3] 和一个int (*p)[2] ; 使 p = a; 然后判断 &a[1][1] - &p[1][1] 是否等于0? 答案当然是否定的:因为,首先。可将数组看成是一个线性表,则:
a[0] a[1] a[1][1] a[2]
|
|
|
|
|
|
|
|
|
p[0] p[1] p[1][1] p[2] p[3] p[4]
从图中可以看出 &a[1][1] - &p[1][1] 等于1,而不等于0;