题目目录
- 第一题
- 第二题
- 第三题
- 第四题
- 第五题
- 第六题
- 第七题
- 第八题
第一题
int main()
{
int a[5] = { 1, 2, 3, 4, 5 };
int *ptr = (int *)(&a + 1);
printf( "%d,%d", *(a + 1), *(ptr - 1));
return 0;
}
//程序的结果是什么?
a与ptr的内存图:
【百炼成钢(LeetCode)|图解八道经典指针笔试题】
data:image/s3,"s3://crabby-images/cdf1d/cdf1db23d99211448c5062f21c0d6354f56d3d24" alt="百炼成钢(LeetCode)|图解八道经典指针笔试题"
文章图片
a + 1和 ptr - 1:
data:image/s3,"s3://crabby-images/c2e2d/c2e2daae0012537bbee113e04279c17a8748f902" alt="百炼成钢(LeetCode)|图解八道经典指针笔试题"
文章图片
解引用后答案为:
2,5第二题
struct Test
{
int Num;
char* pcName;
short sDate;
char cha[2];
short sBa[4];
}*p = 0x100000;
//假设p 的值为0x100000。 如下表表达式的值分别为多少?
int main()
{
printf("%p\n", p + 0x1);
printf("%p\n", (unsigned long)p + 0x1);
printf("%p\n", (unsigned int*)p + 0x1);
return 0;
}
本题涉及结构体大小的计算,有遗忘的小伙伴可以看一看:结构体/联合体大小的计算这道题首先要知道指针加整数要看指针类型,而整数加整数就可以直接加
此结构体的大小为20字节
p+0x1
就是跳过一个p类型大小,就相当于+20(unsigned long)p + 0x1
俩整数相加,直接加(unsigned int*)p + 0x1
跳过p类型大小,相当于+4最后答案为:
0x100020第三题
0x100001
0x100004
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;
}
ptr1跟第一题一样,要注意的是ptr2,(int)a + 1中的+1是加一个字节,而一个整形有四个字节,a是首元素地址,(int)a + 1后:
data:image/s3,"s3://crabby-images/a4775/a477541c208ab33345630cc49fe1fbdb358696e7" alt="百炼成钢(LeetCode)|图解八道经典指针笔试题"
文章图片
而因为ptr2是int* 类型,所以解引用时要向后看四个字节:
data:image/s3,"s3://crabby-images/ba861/ba86126340bbd4cce123c80aa500790b251c70ec" alt="百炼成钢(LeetCode)|图解八道经典指针笔试题"
文章图片
小端存储取出来后就为02 00 00 00
最后的答案为:
4, 2000000(16进制不打印前面的0)第四题
int main()
{
int a[3][2] = { (0, 1), (2, 3), (4, 5) };
int *p;
p = a[0];
printf( "%d", p[0]);
return 0;
}
这里有个陷阱:逗号表达式
真正的内存图:
data:image/s3,"s3://crabby-images/47a58/47a582af10ff6115c79fec9d9f35979258f5d9a1" alt="百炼成钢(LeetCode)|图解八道经典指针笔试题"
文章图片
最后的答案为:
1第五题
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;
}
a[4][2]
很好找,但是p[4][2]
不好找,p指针的类型是int(*)[4]
,p[4][2]
可以看做:data:image/s3,"s3://crabby-images/181df/181dfcd43fe2699e3241a23a5a2087e32c9aadec" alt="百炼成钢(LeetCode)|图解八道经典指针笔试题"
文章图片
&p[4][2] - &a[4][2
]结果是-4data:image/s3,"s3://crabby-images/3ccc3/3ccc3b75f4087a8a19500e61c9657a72552689b5" alt="百炼成钢(LeetCode)|图解八道经典指针笔试题"
文章图片
所以答案为:
FF FF FF FC , -4第六题
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;
}
data:image/s3,"s3://crabby-images/62eb4/62eb48861bc59e14062f3494d70f7796a1f82ae4" alt="百炼成钢(LeetCode)|图解八道经典指针笔试题"
文章图片
答案:
10, 5第七题
int main()
{
char* a[] = { "work","at","alibaba" };
char** pa = a;
pa++;
printf("%s\n", *pa);
return 0;
}
data:image/s3,"s3://crabby-images/07b4d/07b4d672bea5360bf5c4551099390e4623ab399e" alt="百炼成钢(LeetCode)|图解八道经典指针笔试题"
文章图片
pa++
后指向的a指向"at"
答案为:
“at”第八题
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;
}
先把图画出来
data:image/s3,"s3://crabby-images/9e684/9e6844e3b0cb4075ab9f2ff21b119cc2e66866c1" alt="百炼成钢(LeetCode)|图解八道经典指针笔试题"
文章图片
因为打印函数中存在++和- -,会改变下一步的结果,所以要一步步分析
1??
**++cpp
data:image/s3,"s3://crabby-images/b7734/b77341a40f633e6d3bfa3027fcededba9239127c" alt="百炼成钢(LeetCode)|图解八道经典指针笔试题"
文章图片
指向的是
"POINT"
2??
*-- * ++cpp + 3
①++cpp
data:image/s3,"s3://crabby-images/e652a/e652acdf8f22cb131389cbed145f6b856293fe29" alt="百炼成钢(LeetCode)|图解八道经典指针笔试题"
文章图片
②-- * ++cpp
data:image/s3,"s3://crabby-images/c0e8c/c0e8c68c362b40f7716b76f62bdcd5efbab7e56a" alt="百炼成钢(LeetCode)|图解八道经典指针笔试题"
文章图片
③*-- * ++cpp + 3
data:image/s3,"s3://crabby-images/9c760/9c760084eeb056d751640ff375fbcf2abfcfa59f" alt="百炼成钢(LeetCode)|图解八道经典指针笔试题"
文章图片
指向的为
"ER"
3??
*cpp[-2] + 3
data:image/s3,"s3://crabby-images/72493/72493801055ac9ff89b1a763372757905c44718a" alt="百炼成钢(LeetCode)|图解八道经典指针笔试题"
文章图片
data:image/s3,"s3://crabby-images/7b905/7b90524fa87c7d84449eb2459e46dd7e7786d46b" alt="百炼成钢(LeetCode)|图解八道经典指针笔试题"
文章图片
指向的为
"ST"
4??
cpp[-1][-1] + 1
①cpp[-1]
data:image/s3,"s3://crabby-images/c7d35/c7d3520cb327d7b2ea8b3a6e6d7c497fd009a9f2" alt="百炼成钢(LeetCode)|图解八道经典指针笔试题"
文章图片
②cpp[-1][-1]
data:image/s3,"s3://crabby-images/b4988/b49888b3c2e6a33b61e01e0eba0d544bb3b041e6" alt="百炼成钢(LeetCode)|图解八道经典指针笔试题"
文章图片
③cpp[-1][-1] + 1
data:image/s3,"s3://crabby-images/a4b80/a4b80057c87253493ddfa0f349ee0f777dde8ec1" alt="百炼成钢(LeetCode)|图解八道经典指针笔试题"
文章图片
指向的为
"EW"
所以答案为:
POINT
ER
ST
EW
推荐阅读
- C语言|C语言字符串函数详解(strlen strcpy strcat strcmp strstr strtok strerror)
- C语言|C语言—字符/字符串函数—strlen、strcpy、strcat、strcmp、strstr、strtok
- C语言学习|C Primer Plus,C语言精华,截图+代码+学习笔记【10000字】【原创】
- 数据结构与算法(c++)|【20. 滑动窗口】
- 数据结构与算法(c++)|【19. 单调栈】
- C|【c ++ primer 笔记】第4章 表达式
- C|【c ++ primer 笔记】第3章 字符串、向量和数组
- 数据结构与算法(c++)|【18. 模拟栈和队列】
- mediapipe|Mediapipe 人体姿态估计专题(一) Blaze组件算法之Blazeface (带一个小开源分享给大家)