C语言指针进阶笔试题讲解

简介: C语言指针进阶笔试题讲解

前言


十、指针笔试题详解

1.

解释:

2.考察指针+1的知识点

整型指针+1跳过一个整型(4个字节),字符指针+1跳过一个字符(1个字符),在这里p是结构体指针,题目给出这里的结构体指针是20个字节,结构体指针+1跳过一个结构体的大小(20个字节).

😶‍🌫️(1)

p=0x100000

p+0x1 p是结构体类型,跳过20个字节,用16进制表示结果为0x10014

打印的结果为00100014

😶‍🌫️(2)

将p=0x100000强制转换成无符号整型,整型+1就是仅仅+1.注意:16进制只是数值的表示形式,不同的进制可以表示同一个值

打印的结果为00100001

😶‍🌫️(3)

将p强制转换成unsigned int*的指针类型,这样的指针类型指向的是unsigned int类型的数据,+1跳过一个int类型(4个字节),所以p的值变为0x100004

打印的结果为00100004

🐾最后注意这三个结果都是以地址的形式打印出来,地址在X86的环境下打印出来应该是8位16进制的数字,高位这个时候会补0.

如果是用%x来打印16进制数字,就不会在高位补0了.

%p打印

%x打印

3.

讲解:

结果:

4.

注意这里的数组在初始化的时候,里面用的是(),不会达到下图的效果,如果想要达到下图的效果,应该把()改为{}

当用()括起来的时候,这叫逗号表达式.

逗号表达式会从左往右依次计算,但整个表达式的结果是最后一个表达式的结果.比如(0.1)结果是1,(2,3)结果是3,(4,5)结果是5

所以实际上这个数组初始化的是1,3,5

a数组里面实际是:

a[0] 第一行的数组名(没有单独放到sizeof内部,也没有&,所以数组名表示首元素的地址,也就是第一行第一个元素1的地址)

p=a[0];

p[0] --> *(p+0) --> *p

p是整型指针,解引用访问一个整型,得到的就是1

结果

😶‍🌫️注意😶‍🌫️:

二维数组一行的数组名,数组名表示首元素的地址,数组名没有单独放到sizeof内部,也没有&,所以数组名表示首元素的地址,也就是第一行第一个元素的地址

5.

p是数组指针,指向的数组有四个元素,每个元素是整型.

p=a; //把a赋值给p,能赋值过去吗?

a是二维数组的数组名,表示首元素的地址也就是第1行的地址,代表的是5个整型的一维数组

a的类型:int() [5]
p的类型:int(
) [4]

a和p的类型不一样,赋值的时候可能会有警告存在类型差异,但是强制赋值的话也是可以赋值的过去.还是会把第一行的地址赋值给p

题解:

注意:

%p 把内存中的补码的值直接打印出来

%d 把内存中的补码转换成原码再打印出来

结果:

6.

初始化数组两行五列:

数字在内存中存放是连续的:

&aa取到的是整个数组的地址,+1跳过整个数组后的地址

ptr1 整型指针

-1 向前挪动一个整型

aa数组名是二维数组首元素的地址,也就是第一行的地址,+1 第一行的地址+1跳过1行指向下图所示的位置

aa+1是第二行的地址,(aa+1)解引用拿到第二行,也相当于拿到第二行的数组名,因为 (aa+1)可以写成aa[1].
作为第二行的数组名,没有单独放在sizeof内部,也没有&,所以这里
(aa+1)表示第二行第一个元素的地址
int
ptr2 = (int*)((aa + 1));//这里的强制类型转换没必要,因为((aa + 1)本身就是整型指针

最后ptr1-1,ptr2-1解引用,得到结果10,5

7.

a是指针数组

*pa得到at中a的地址,以%s打印时,%s需要一个地址就可以打印出后面的字符串,向后输出内容,结果是at

8.

图解:

(1)>++cpp ,cpp改变>*++cpp 拿到了c+2,c+2是P的地址>**++cpp 拿到了P的地址>这时以%s打印,就打印出字符串 POINT

(2)

先算++cpp

解引用找到c+1

再- -,里面就不是c+1了,变成c

注意变成c之后,就不再指向原来c+1指向的位置了,而是指向c的位置

然后再解引用,

找到的是E的地址

最后再加3,指向的是E的地址

用&s打印,把E后面的字符串打印出来

所以结果是ER

😶‍🌫️注意:😶‍🌫️

后缀的操作符优先级比前缀高,前缀的比±*/高

(3)

*cpp[2] 等价于 * *(cpp-2)+3

注意现在cpp-2的位置:

(cpp-2) 拿到了c+3
**(cpp-2) 再解引用,相当于给c+3解引用,找到了FIRST的地址也就是F的地址
F的地址是char
类型的,+3指向S的地址

把S的地址交给%s打印,打印出来的就是ST

(4)

cpp[-1][-1] 等价于 ((cpp-1)-1)+1

cpp-1在哪?见下图

*(cpp-1) 拿到 c+2

(cpp-1)-1 也就是c+2-1=c+1
注意c+1在哪呢?

如图c+1指向的是NEW的地址,
((cpp-1)-1) 解引用通过c+1找到了NEW的地址,也就是N的地址
((cpp-1)-1)+1 N的地址再加1,N的地址是char
类型的,+1也就是E的地址,以%s打印,结果出来的是EW

结果:

总结

通过指针笔试题的学习之后,我深刻认识到了画图对于理解代码的重要性,同时也对指针的运用有了更深的了解.

指针的内容就讲解到这里啦,如果对友友们有帮助的话,可以点赞收藏博客,关注后续的C语言学习内容哦👻👻

目录
打赏
0
0
1
0
2
分享
相关文章
【C语言】指针的神秘探险:从入门到精通的奇幻之旅 !
指针是一个变量,它存储另一个变量的内存地址。换句话说,指针“指向”存储在内存中的某个数据。
128 3
【C语言】指针的神秘探险:从入门到精通的奇幻之旅 !
【C语言】指针大小知多少 ?一场探寻C语言深处的冒险 !
在C语言中,指针的大小(即指针变量占用的内存大小)是由计算机的体系结构(例如32位还是64位)和编译器决定的。
209 9
【C语言】指针的爱恨纠葛:常量指针vs指向常量的指针
在C语言中,“常量指针”和“指向常量的指针”是两个重要的指针概念。它们在控制指针的行为和数据的可修改性方面发挥着关键作用。理解这两个概念有助于编写更安全、有效的代码。本文将深入探讨这两个概念,包括定义、语法、实际应用、复杂示例、最佳实践以及常见问题。
67 7
C语言如何使用结构体和指针来操作动态分配的内存
在C语言中,通过定义结构体并使用指向该结构体的指针,可以对动态分配的内存进行操作。首先利用 `malloc` 或 `calloc` 分配内存,然后通过指针访问和修改结构体成员,最后用 `free` 释放内存,实现资源的有效管理。
302 13
C 语言数组与指针的深度剖析与应用
在C语言中,数组与指针是核心概念,二者既独立又紧密相连。数组是在连续内存中存储相同类型数据的结构,而指针则存储内存地址,二者结合可在数据处理、函数传参等方面发挥巨大作用。掌握它们的特性和关系,对于优化程序性能、灵活处理数据结构至关重要。
C语言中的文件操作技巧,涵盖文件的打开与关闭、读取与写入、文件指针移动及注意事项
本文深入讲解了C语言中的文件操作技巧,涵盖文件的打开与关闭、读取与写入、文件指针移动及注意事项,通过实例演示了文件操作的基本流程,帮助读者掌握这一重要技能,提升程序开发能力。
241 3
C 语言指针详解 —— 内存操控的魔法棒
《C 语言指针详解》深入浅出地讲解了指针的概念、使用方法及其在内存操作中的重要作用,被誉为程序员手中的“内存操控魔法棒”。本书适合C语言初学者及希望深化理解指针机制的开发者阅读。
C语言中的指针既强大又具挑战性,它像一把钥匙,开启程序世界的隐秘之门
C语言中的指针既强大又具挑战性,它像一把钥匙,开启程序世界的隐秘之门。本文深入探讨了指针的基本概念、声明方式、动态内存分配、函数参数传递、指针运算及与数组和函数的关系,强调了正确使用指针的重要性,并鼓励读者通过实践掌握这一关键技能。
74 1
在C语言中指针数组和数组指针在动态内存分配中的应用
在C语言中,指针数组和数组指针均可用于动态内存分配。指针数组是数组的每个元素都是指针,可用于指向多个动态分配的内存块;数组指针则指向一个数组,可动态分配和管理大型数据结构。两者结合使用,灵活高效地管理内存。
C 语言中指针数组与数组指针的辨析与应用
在C语言中,指针数组和数组指针是两个容易混淆但用途不同的概念。指针数组是一个数组,其元素是指针类型;而数组指针是指向数组的指针。两者在声明、使用及内存布局上各有特点,正确理解它们有助于更高效地编程。

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等