👁️6.指针笔试题
👀6.1.试题(1)
💡下面代码输出的结果是什么?
int main() { int a[5] = { 1,2,3,4,5 }; int* ptr = (int*)(&a + 1); printf("%d,%d", *(a + 1), *(ptr - 1)); return 0; }
👀6.2.试题(2)
💡假设p的值为0x100000 如下表达式的值分别为多少?
struct Test { int Num; char* pcName; short sDate; char cha[2]; short sBa[4]; }*p; //假设p的值为0x100000 如下表达式的值分别为多少? //已知,结构体Test类型的变量大小是20个字节 int main() { p = (struct Test*)0x100000; printf("%p\n", p + 0x1); printf("%p\n", (unsigned long)p + 0x1); printf("%p\n", (unsigned int*)p + 0x1); return 0; }
🔴(1)这里因为 p 是结构体类型+1,+1跳过20个字节,因此结果为0x100014(十六进制)
🔴(2)这里 p 被强制类型转换为整型,所以 p+1 就是整型+1,因此结果为0x100001
🔴(3)这里 p 被强制类型转换为整型指针,所以 p+1 跳过4个字节,因此结果为0x100004
👀6.3.试题(3)
💡下面代码输出的结果是什么?
int main() { int a[4] = {1,2,3,4}; int* ptr1 = (int*)(&a + 1); int* ptr2 = (int*)((int)a + 1); printf("%x,%x", ptr1[-1], *ptr2); return 0; }
👀6.4.试题(4)
💡下面代码输出的结果是什么?
int main() { int a[3][2] = { (0,1),(2,3),(4,5) }; int* p; p = a[0]; printf("%d",p[0]); return 0; }
🔴这里一不小心就可能上当掉坑里‼️
这道题如果真正定义二维数组的话应该是这样:int a[3][2] = { {0,1},{2,3},{4,5} };
而这道题考察的是逗号表达式,里面不是 {} 而是 ()
🔴a[0] 是二维数组第一行的数组名
🔴对 a[0] 这个数组名没有&,也没有单独的sizeof
🔴所以 a[0] 这个数组名表示数组首元素地址,即 a[0][0] 的地址
🔴a[0] —> &a[0][0]
🔴p[0] —> * (p+0) —>* p
👀6.5.试题(5)
💡下面代码输出的结果是什么?
int main() { int a[5][5]; int(*p)[4]; p = a; printf("%p,%d\n", &p[4][2] - &a[4][2], &p[4][2] - &a[4][2]); return 0; }
🔴-4 10000000000000000000000000000100 -- 原码 11111111111111111111111111111011 -- 反码 11111111111111111111111111111100 -- 补码 0x FF FF FF FC
👀6.6.试题(6)
💡下面代码输出的结果是什么?
int main() { int aa[2][5] = { 1,2,3,4,5,6,7,8,9,10 }; int* ptr1 = (int*)(&aa + 1); int* ptr2 = (int*)(*(aa + 1)); printf("%d,%d", *(ptr1 - 1), *(ptr2 - 1)); return 0; }
🔴根据以上几道题可以自己思考一下,这道题比较简单🥰
👀6.7.试题(7)
💡下面代码输出的结果是什么?
int main() { char* a[] = { "work","at","alibaba" }; char** pa = a; pa++; printf("%s\n", *pa); return 0; }
👀6.8.试题(8)
💡下面代码输出的结果是什么?
int main() { char* c[] = { "ENTER","NEW","POINT","FIRST" }; char** cp[] = {c + 3,c + 2,c + 1,c}; char*** cpp = cp; printf("%s\n", **++cpp); printf("%s\n", *-- * ++cpp + 3); printf("%s\n", *cpp[-2] + 3); printf("%s\n", cpp[-1][-1] + 1); return 0; }
🔴这道题比较有难度,如果这道题可以完全理解,那么说明对于指针的学习还是不错的🥳
🔴一定要自己独立画图理解‼️
🥰今天的内容比较有难度,希望烙铁们能够理解欧‼️🥰