C语言 图解指针与指针数组笔试题2,让你也能感觉指针如此简单

下面将继续上文章的指针笔试题,讲解8题指针笔试题2版,将会进行分析和画图讲解。如果想指针验证评估自己的指针地基是否牢固以及有兴趣的初学者,可以尝试挑战。

话不多说,边上题做边讲解

热身1

int main() {

	int a[] = { 1,2,3,4,5 };
	
	int* ptr = (int*)(&a + 1);
	printf("%d,%d\n",*(a+1),*(ptr-1));
	//a+1首元素地址+1,解引用得到2
	//存入ptr=(&a+1)指针从1的前面跳到5的后面;ptr-1跳到5的前面;

	return 0;
}

答案+图解

int main() {

	int a[] = { 1,2,3,4,5 };
	
	int* ptr = (int*)(&a + 1);
	printf("%d,%d\n",*(a+1),*(ptr-1));//2,5
	//a+1首元素地址+1,解引用得到2
	//存入ptr=(&a+1)指针从1的前面跳到5的后面;ptr-1跳到5的前面;

	return 0;
}

图解
在这里插入图片描述

笔试题2

struct Test
{
	int Num;
	char* pcName;
	short sDate;
	char cha[2];
	short sBa[4];
	
}*p;//p=0x00000000  下面的结果是

int main() {

	printf("%p\n", p + 0x1);
	printf("%p\n", (unsigned long)p + 0x1);
	printf("%p\n", (unsigned int*)p + 0x1);
	
	return 0;
}

答案+图解

struct Test
{
	int Num;
	char* pcName;
	short sDate;
	char cha[2];
	short sBa[4];

}*p;//*代表这是个结构体指针
//p=0x00000000,下面的结果是


int main() {
	printf("%p\n", p + 0x1);//0x00000014
	printf("%p\n" ,p + 1);//和上面的等价		//这里是->地址+1
	//0x1相当于二进制的1,也就是p(数据类型20个字节)的地址+1;
	//跳过一个结构体大小20个字节=0x0000014  /这个1是16(十六进制满16进1),4是4,16+4=20
	
	printf("%p\n", (unsigned long)p + 0x1);//0x00000001//   这里是->整型+1     
	//  强转为长整型;转化成整型之后+1,加的就是1	==0x00000001【例如10+1就是11】
	
	printf("%p\n", (unsigned int*)p + 0x1);//0x00000004
	//整型指针跳过4个字节
	return 0;
}

图解
在这里插入图片描述

⭐笔试题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;
}

答案+图解


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);//4(0x00000004), 2000000 (0x02000000)
									
	return 0;
}

图解1
在这里插入图片描述
图解2

在这里插入图片描述

笔试题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 main() {

	int a[3][2] = { (0,1),(2,3),(4,5) };//逗号表达式等价={{1,3},{5,0},{0,0}}
	int* p;
	p = a[0];//都知道p=1的地址(上节有)
	
	printf("%d", p[0]);//1     p[0]相当于*(p+0)

	return 0;
}

图解

简单没图(不是所有牛奶都叫牛奶,不是所有图解都有图)

⭐笔试题5

int main() {

	int a[5][5];
	int(*p)[4];
	p = a;

	printf("%p,%d\n",&p[4][2],&a[4][2]);

	return 0;
}

答案+图解

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]);//FFFFFFFC,-4
	
	return 0;
}

图解

在这里插入图片描述

⭐笔试题6

int main() {

	int a[2][5] = { 1,2,3,4,5,6,7,8,9,10 };
	int* ptr1 = (int*)(&a+1);
	int* ptr2 = (int*)(*(a+1));

	printf("%d,%d", *(ptr1 - 1), *ptr2 - 1);

	return 0;
}

答案+图解

int main() {

	int a[2][5] = { 1,2,3,4,5,6,7,8,9,10 };
	int* ptr1 = (int*)(&a+1);
	int* ptr2 = (int*)(*(a+1));

	printf("%d,%d", *(ptr1 - 1), *(ptr2 - 1));//10,5

	return 0;
}

图解

在这里插入图片描述

笔试题7

int main() {

	char* a[] = { "work","at","alibaba" };
	char** pa = a;
	pa++;

	printf("%s", *pa);

	return 0;
}

答案+图解

int main() {

	char* a[] = { "work","at","alibaba" };
	char** pa = a;
	pa++;

	printf("%s", *pa);//at

	return 0;
}

图解

在这里插入图片描述

⭐笔试题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;
}

答案+题解

int main() {

	char* c[] = { "ENTER","NEW","POINT","FIRST" };
	char** cp[] = { c + 3,c + 2,c + 1,c };
	char*** cpp = cp;

	printf("%s\n", **++cpp);//POINT
	printf("%s\n", *-- * ++cpp + 3);//ER
	printf("%s\n", *cpp[-2] + 3);//ST
	printf("%s\n", cpp[-1][-1] + 1);//EW

	return 0;
}

图解
在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

卡涂

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值