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

【进阶C语言】指针笔试题(详解)_第1张图片

前言

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


指针笔试题

  • 前言
    • 笔试题1
    • 笔试题2
    • 笔试题3
    • 笔试题4
    • 笔试题5
    • 笔试题6
    • 笔试题7
    • 笔试题8

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

代码结果:
【进阶C语言】指针笔试题(详解)_第2张图片
图片讲解:
【进阶C语言】指针笔试题(详解)_第3张图片

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

代码结果:
【进阶C语言】指针笔试题(详解)_第4张图片
详细讲解:

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

图片讲解:
【进阶C语言】指针笔试题(详解)_第5张图片

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

代码结果:
【进阶C语言】指针笔试题(详解)_第6张图片

详细讲解:

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

图片讲解:
在这里插入图片描述
【进阶C语言】指针笔试题(详解)_第7张图片

a为首元素地址,假设a的地址是0x0012ff40,(int)a强制类型转换为整型,整型加1,变成0x0012ff41
【进阶C语言】指针笔试题(详解)_第8张图片

【进阶C语言】指针笔试题(详解)_第9张图片

笔试题4

int main()
{
	int a[3][2] = { (0, 1), (2, 3), (4, 5) };
	int* p;
	p = a[0];
	printf("%d", p[0]);
	return 0;
}

代码结果:
【进阶C语言】指针笔试题(详解)_第10张图片
详细讲解:

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

图片讲解:
【进阶C语言】指针笔试题(详解)_第11张图片

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

代码结果:
【进阶C语言】指针笔试题(详解)_第12张图片

图片讲解:
在这里插入图片描述
【进阶C语言】指针笔试题(详解)_第13张图片

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

图片讲解:
【进阶C语言】指针笔试题(详解)_第14张图片

笔试题7

int main()
{
	char* a[] = { "work","at","alibaba" };
	char** pa = a;
	pa++;
	printf("%s\n", *pa);
	return 0;
}

图片讲解:
【进阶C语言】指针笔试题(详解)_第15张图片
【进阶C语言】指针笔试题(详解)_第16张图片

笔试题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语言】指针笔试题(详解)_第17张图片

图片讲解:

第一个数组大致的样子:
【进阶C语言】指针笔试题(详解)_第18张图片
第二个数组大致的样子:
【进阶C语言】指针笔试题(详解)_第19张图片
第三个数组大致的样子:
【进阶C语言】指针笔试题(详解)_第20张图片
**++p的样子:
结果为:POINT

【进阶C语言】指针笔试题(详解)_第21张图片
注意:此时cpp的位置已经发生变化,从变化位置开始计算,printf(“%s\n”, *-- * ++cpp + 3)
先++:
【进阶C语言】指针笔试题(详解)_第22张图片
*-- * ++cpp的样子:
【进阶C语言】指针笔试题(详解)_第23张图片
printf(“%s\n”, *-- * ++cpp + 3)的样子:
【进阶C语言】指针笔试题(详解)_第24张图片
printf(“%s\n”, *cpp[-2] + 3);
在这里插入图片描述
【进阶C语言】指针笔试题(详解)_第25张图片
printf(“%s\n”, cpp[-1][-1] + 1)的样子:
在这里插入图片描述
变成c+2-1:
【进阶C语言】指针笔试题(详解)_第26张图片
总结:
a++和a[ 1 ]不一样
【进阶C语言】指针笔试题(详解)_第27张图片

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

你可能感兴趣的:(进阶C语言,c语言,算法,c++,经验分享)