今天遇到一道题:
char ch[100] = "";
int* p_ch = (int*)ch;
p_ch += 10;
printf("%d, %d\n", (p_ch - (int*)ch), ((void*)p_ch - (void*)ch));
前面的答案肯定是10(sizeof(int)= 4)。
至于后面这个表示式这种语法是有问题的,要看编译器,像ansi c是不允许void*之间进行算数运算,如果是gnu,void*默认跟char*是一样的,即sizeof(void*) == sizeof(char*),那么答案是40。
char ch[100] = "1234567890";
int* p_ch = (int*)ch;
printf("%d\n", *p_ch);
p_ch += 2;
printf("%d\n", *p_ch);
前面的输出是875770417,后面的输出是12345。
指针位移前,取p_ch指向的一个int,那就是取四个字节,取到的是'4','3','2','1',根据ascii转换得到52,51,50,49,转换为二进制得到0011 0100 0011 0011 0011 0010 0011 0001,转换为十进制就是875770417。
位移后,取p_ch指向的一个int,得到0,0,9,0,同样方法算出12345。
至于为什么取到的是4321,不是1234,是因为在栈上,地址是从高分配到底的。