指针经典笔试题详解-指针、大小端、操作符、原反补

指针大小及小端存储模式

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

在这里插入图片描述
由于当前计算机是小端存储模式,如果对大小端不懂的可以看 大小端区别 因此a的存储方式如图所示,此时 ptr1 指向 数组的结束后的位置,而ptr2=(int)a+1指向的是数组的首元素的地址向后偏移一位的地址。
因此当得到ptr2 的结果的时候 ptr2的数据为 00 00 00 02 又因为小端存储模式 因此最终ptr2的结果为 2000000

函数指针及原反补

#include <stdio.h>
int main()
{
	int a[5][5];
	int(*p)[4];
	p = a; // p=int (*)[4]   a=int (*)[5]
	printf("%p,%d\n", &p[4][2] - &a[4][2], &p[4][2] - &a[4][2]);
	return 0;
}

在这里插入图片描述
由于p的大小是4,因此p+1 == a[0][4] p+2==a[1][3] 以此类推 p[4][2]==a[3][4]
又因为大小端所以 结果为 -4 而在打印地址的时候 是无符号数 最高位当做有效位 因此结果为 FFFFFFFC
对于原反补不理解的可以看 原码、反码和补码

指针及操作符

#include <stdio.h>
int main()
{
	char* c[] = { "ENTER","NEW","POINT","FIRST" };
	char** cp[] = { c + 3,c + 2,c + 1,c }; // FIRST POINT NEW ENTER
	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;
}

在这里插入图片描述
最开始 ***cpp指向的是 cp的首地址 就是 c+3 但是 ++cpp操作符后,***cpp就指向了 cp的 c+2。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值