指针笔试题(带解析版)

题目2:

cpp 复制代码
struct MyStruct
{
	int num;
	char* pcname;
	short sdate;
	char cha[2];
	short sba[4];
}*p;
//结构体大小为32字节
//p=0x100000
int main()
{
	p = 0x100000;
	printf("%p\n", p + 0x1);
	//p:结构体指针,+1=下一个结构体指针,所以 p + 1 的地址比 p 高32字节
	//p+1=p+结构体大小=p+32(10进制)=0010 0000+0000 0020=0010 0020
	printf("%p\n", (unsigned long)p + 0x1);
	//0x10 0000(16进制)=1048576(10进制)
	//加1会增加地址的值,而不是指向下一个结构体
	//1048576+0x1(16进制)=1048576+1(10进制)=1048577=0010 0001(16进制)
	printf("%p\n", (unsigned int*)p + 0x1);
	//unsigned int*:整型指针类型,指针+1=下一个指针
	// 尽管平台是64位的,但是 unsigned int 的大小在几乎所有平台上都是4字节(32位),而不是8字节(64位)
	//p+1=p+4(64平台)=0010 0000+4(16进制)=0010 0000+8(10进制)=0010 0004
	return 0;
}

题目1:

cpp 复制代码
int main()
{
	int a[4] = { 1,2,3,4 };
	int* ptr1 = (int*)(&a + 1);
	//&a + 1:指向元素4右边的地址
	//(int*)(&a + 1):强制转换为int*类型
	int* ptr2 = (int*)((int)a + 1);
	//(int)a:数组首元素
	printf("%x,%x\n", ptr1[-1], *ptr2);
	//ptr1[-1]=*(ptr1+(-1))=*(ptr1-1)=指向元素4右边的地址向左边移动一位=4
	return 0;
}

解析:

相关推荐
算法鑫探8 小时前
闰年判断:C语言实战解析
c语言·数据结构·算法·新人首发
WBluuue8 小时前
数据结构与算法:康托展开、约瑟夫环、完美洗牌
c++·算法
木子墨5168 小时前
LeetCode 热题 100 精讲 | 并查集篇:最长连续序列 · 岛屿数量 · 省份数量 · 冗余连接 · 等式方程的可满足性
数据结构·c++·算法·leetcode
浅时光_c8 小时前
14 结构体 共用体 枚举类型
c语言
2501_921960859 小时前
双相自指图与弦论边界非对易性的结构同源
数据结构
王老师青少年编程9 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【线性扫描贪心】:均分纸牌
c++·算法·编程·贪心·csp·信奥赛·均分纸牌
EQUINOX19 小时前
2026年码蹄杯 本科院校赛道&青少年挑战赛道提高组初赛(省赛)第一场,个人题解
算法
萝卜小白9 小时前
算法实习Day04-MinerU2.5-pro
人工智能·算法·机器学习
Liangwei Lin9 小时前
洛谷 P3133 [USACO16JAN] Radio Contact G
数据结构·算法
weixin_5134499610 小时前
PCA、SVD 、 ICP 、kd-tree算法的简单整理总结
c++·人工智能·学习·算法·机器人