【进阶C语言】指针笔试题(详解)

在这里插入图片描述

前言

如果这份博客对大家有帮助,希望各位给恒川一个免费的点赞作为鼓励,并评论收藏一下,谢谢大家!!!
制作不易,如果大家有什么疑问或给恒川的意见,欢迎评论区留言。


笔试题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;
}
//程序的结果是什么?

代码结果:
在这里插入图片描述
图片讲解:
在这里插入图片描述

笔试题2

//这里告知结构体的大小是20个字节
struct Test
{
    
    
	int Num;
	char* pcName;
	short sDate;
	char cha[2];
	short sBa[4];
}*p;
//假设p 的值为0x100000。 如下表表达式的值分别为多少?
//已知,结构体Test类型的变量大小是20个字节
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 的值为0x100000。 如下表表达式的值分别为多少?
//已知,结构体Test类型的变量大小是20个字节
int main()
{
    
    
	p = (struct Test*)0x100000;
	printf("%p\n", p + 0x1);
	printf("%p\n", (unsigned long)p + 0x1);//这里指的是整型加1
	printf("%p\n", (unsigned int*)p + 0x1);//这里指的是指针加1
	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;
}

代码结果:
在这里插入图片描述

详细讲解:

a为首元素地址,假设a的地址是0x0012ff40,(int)a强制类型转换为整型,整型加1,变成0x0012ff41

图片讲解:
在这里插入图片描述
在这里插入图片描述

扫描二维码关注公众号,回复: 14641130 查看本文章

a为首元素地址,假设a的地址是0x0012ff40,(int)a强制类型转换为整型,整型加1,变成0x0012ff41
在这里插入图片描述

在这里插入图片描述

笔试题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) };//该为逗号表达式
	//int a[3][2] = { {0, 1}, {2, 3}, {4, 5} };//这才是真正数组的情况
	int* p;
	p = a[0];
	printf("%d", p[0]);
	//a[0]是二维数组第一行的数组名
	//对a[0]这个数组名没有&,没有单独sizeof
	//所有a[0]这个数组名表示数组首元素的地址,即a[0][0]的地址
	//a[0]----->&a[0][0]
	//p[0]----->*(p+0)--*p
	return 0;
}

a[ 0 ]是二维数组第一行的数组名
对a[ 0 ]这个数组名没有&,没有单独sizeof
所有a[ 0 ]这个数组名表示数组首元素的地址,即a[ 0 ][ 0 ]的地址
a [ 0 ]----->&a[ 0 ][ 0 ]
p[ 0 ]----->*(p+0)–*p

图片讲解:
在这里插入图片描述

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

代码结果:
在这里插入图片描述

图片讲解:
在这里插入图片描述
在这里插入图片描述

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

图片讲解:
在这里插入图片描述

笔试题7

int main()
{
    
    
	char* a[] = {
    
     "work","at","alibaba" };
	char** pa = a;
	pa++;
	printf("%s\n", *pa);
	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;
}

代码结果:
在这里插入图片描述

图片讲解:

第一个数组大致的样子:
在这里插入图片描述
第二个数组大致的样子:
在这里插入图片描述
第三个数组大致的样子:
在这里插入图片描述
**++p的样子:
结果为:POINT

在这里插入图片描述
注意:此时cpp的位置已经发生变化,从变化位置开始计算,printf(“%s\n”, *-- * ++cpp + 3)
先++:
在这里插入图片描述
*-- * ++cpp的样子:
在这里插入图片描述
printf(“%s\n”, *-- * ++cpp + 3)的样子:
在这里插入图片描述
printf(“%s\n”, *cpp[-2] + 3);
在这里插入图片描述
在这里插入图片描述
printf(“%s\n”, cpp[-1][-1] + 1)的样子:
在这里插入图片描述
变成c+2-1:
在这里插入图片描述
总结:
a++和a[ 1 ]不一样
在这里插入图片描述

如果这份博客对大家有帮助,希望各位给恒川一个免费的点赞作为鼓励,并评论收藏一下,谢谢大家!!!
制作不易,如果大家有什么疑问或给恒川的意见,欢迎评论区留言。

猜你喜欢

转载自blog.csdn.net/m0_75058342/article/details/129819890