当前位置: 首页 > article >正文

指针和数组笔试题解析【下篇】

文章目录

  • 👁️6.指针笔试题
    • 👀6.1.试题(1)
    • 👀6.2.试题(2)
    • 👀6.3.试题(3)
    • 👀6.4.试题(4)
    • 👀6.5.试题(5)
    • 👀6.6.试题(6)
    • 👀6.7.试题(7)
    • 👀6.8.试题(8)

在这里插入图片描述

👁️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;
}

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

🔴这道题比较有难度,如果这道题可以完全理解,那么说明对于指针的学习还是不错的🥳
🔴一定要自己独立画图理解‼️

🥰今天的内容比较有难度,希望烙铁们能够理解欧‼️🥰

总结🥰
以上就是 指针和数组笔试题解析【下篇】 的内容啦🥳🥳🥳🥳
本文章所在【C语言知识篇】专栏,感兴趣的烙铁可以订阅本专栏哦🥳🥳🥳
希望我们可以做一个用心的人💕💕💕
小的会继续学习,继续努力带来更好的作品😊😊😊
创作写文不易,还多请各位大佬uu们多多支持哦🥰🥰🥰

请添加图片描述


http://www.kler.cn/a/205.html

相关文章:

  • 【工具变量】统计行业锦标赛激励数据集(2008-2023年)
  • C++和Python中负数取余结果的区别
  • docker minio镜像arm64架构
  • 基于phpstudy快速搭建本地php环境(Windows)
  • 如何 cURL Elasticsearch:进入 Shell
  • nginx-链路追踪(trace)实现
  • 【ChatGPT 论文阅读神器】SciSpace 用户注册与实战测试
  • 观察者模式与发布订阅模式
  • 【C语言】数据结构|链表|入门|leetcode
  • visual-chatgpt国内劝退指南
  • C++和C的区别
  • Docker圣经:大白话说Docker底层原理,6W字实现Docker自由
  • 如何使用 Python 检测和识别车牌(附 Python 代码)
  • ChatGPT在工业领域的用法
  • Android binder通信实现进程间通信
  • 通过WiFi连接adb调试
  • 如何保证Redis缓存和数据库一致性?
  • 外卖点餐系统小程序 PHP+UniAPP
  • 如何通过C++ 将数据写入 Excel 工作表
  • 刷题专练之链表(一)
  • SQL执行过程详解
  • 教你成为比卡卡西还牛逼的全能忍者,全拷贝与分割函数
  • 蓝桥杯C++组怒刷50道真题
  • 金三银四、金九银十 面试宝典 Spring、MyBatis、SpringMVC面试题 超级无敌全的面试题汇总(超万字的面试题,让你的SSM框架无可挑剔)
  • 【JavaScript 逆向】百度旋转验证码逆向分析
  • 大数据分析案例-基于决策树算法预测ICU患者是否需要插管