指针大厂笔试真题讲解(c语言篇)

news2025/1/13 10:17:59

        大家好,我是c语言boom家宝,今天为大家带来的是c语言指针内容在大厂笔试中的真题讲解,希望能让初学者对指针有更深入的理解。

        ps:如有侵权,请私信联系,立刻删除。

真题一:

答案:2   ,  5 。

 解析:字母a是数组名,所以&a就表示整个数组,但是指向的是数组首元素的地址,而&a+1过后就是跳过一整个数组大小的字节,也就是指向这个数组末尾元素的后面的地址。然后再把它解引用并强制转换成int*类型然后用prt指针指向它的地址。为什么是强转成int*类型呢?他不还是指向地址吗?因为这个本身的类型是int(*)[5],是一个数组指针类型,对他解引用过后能操作的范围是整个数组的大小。现在强制转换成int*类型过后再进行解引用操作就只能操作一个整型的范围了。所以如果打印*(ptr-1)就是打印的5,而a表示首元素的地址,a+1就表示第二个元素的地址,*(a+1)解引用就打印的是2。所以最后答案就是2,5。如图:

真题二:

答案:    0x100014,0x100001,0x100004

 解析:这道题很简单,甚至都不需要画图帮助理解。第一个问题p的值为0x100000,p + 0x1就等于加一,这个加一表示着跳过一个结构体的大小,而结构体类型的变量大小是20字节,所以就等于加了一个十进制的20,换成16进制是0x000014,所以加起来就是0x100014.第二个问题要把它强制转换成unsigned long类型,无符号长整型的加减法就是直接的加减法,加上1就表示值的大小加1,所以输出结果就是0x100001。第三个问题是强制转换成unsigned int*类型,加1就是跳过4个字节,所以输出结果就是0x100004。

真题三假设当前机器是小端机器,请计算下面结果

答案:4,    2000000

解析:因为题目有告知当前代码是在小端机器上运行的,所以我们可以很快速的画出下面的图:

&a表示整个数组的地址,&a+1就表示跳过整个数组,即指向数组最后一个元素的后面的地址。同样的,把&a+1强制转换成int*类型再赋值给ptr1以后,那么ptr1也是指向和&a+1一样的地址,不过类型不是int(*)[],而是int*,对ptr1只能操作一个整型的变量。ptr[-1]即表示*(ptr1-1),而ptr1-1只能跳过一个整型,所以解引用过后表示的是0x00000004。但是以%x打印,编译器是不会打印出16进制的前面为0的部分,所以第一个问题打印的答案是4。第二问:先把a强制转换成int类型,那么加一就是单纯的值加一,本身a表示的是首元素的地址,指向01,加一跳过一个整型,指向00。然后强转成int*类型。又因为是小端机器,所以对ptr2进行解引用就表示的是0x02000000,%x的方式打印就是20000000。如图:

真题四:

答案:  1

解析:首先,如果我们不够仔细的话,就会掉入陷阱。题目的二维数组大括号里面是用的三个小括号分隔开的,那么他其实是逗号表达式,逗号表达式就是从左到右最后的结果就是最终的结果。所以这个数组实际上存储的内容是{1,3,5,0,0,0}。p=a[0],所以p指向的是a[0][0]的地址,也就是指向的1 。而打印的内容是p[0],也就是*(p+0)=*p的值,也就是1了。

真题五:

答案:FFFFFFFC   ,   -4

解析:首先,a是数组指针,类型是int(*)[5],而p的类型是int(*)[4]。现在要把a的值赋给p,只能强行转换了。a指向的是数组首元素的地址,赋给p过后,p也指向了数组首元素的地址。然后我们可以简单画一个图:

 因为p是int(*)[4]的类型,所以在上图中就是以4为一组的划分,a是以5为一组的划分。通过上图,我们也可以很轻易的找到&p[4][2]和&a[4][2]的地址。而地址是由低到高变化的,所以上图中左边是低地址,右边是高地址,故而&p[4][2]  -  &a[4][2]用%d的形式打印就是-4,因为他们如上图他们之间隔了4个,又是小的减去大的,所以是负四。而用%p形式打印,我们就需要把-4转换成原码,为1000000000000000000000000100,在转换成反码就是11111111111111111111111111111011,补码就是反码加一等于11111111111111111111111111111100,而%p打印才不管你是不是无符号位,直接把你这个补码当成地址打印了。所以我们只需要把内存中的这个补码转成16进制打印就行,4个2进制位换算成1个16进制,所以最后答案就是FFFFFFFC。

真题6:

答案:10  ,  5

解析:&aa表示首元素地址,加一过后跳过整个数组,即指向数组最后一个元素的后面的地址。强转成int*类型过后再给ptr1,并且打印*(ptr1 - 1)的值,这个问题在前面已经出现过很多次了,相信大家能直接说出答案就是10 。而ptr2是由*(aa+1)强转过来的,aa+ 1表示的是数组aa[1][ ]的内容,指向的是aa[1][0]的地址,也就是6,所以ptr2 - 1就是指向的5的地址,解引用过后打印的就是5 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/778070.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SpringCloud分布式项目下feign的使用

新建一个feign的微服务&#xff08;后面统称为A&#xff09;&#xff0c;其他项目要使用利用maven导入该服务模块的依赖就行了 导入依赖 <dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-openfeign</…

【C++】STL——list的使用和介绍、list的构造函数及其使用、list迭代器及其使用

文章目录 1.list的介绍和使用2.list的构造函数&#xff08;1&#xff09;list (size_type n, const value_type& val value_type()) &#xff08;2&#xff09;list() 构造空的list&#xff08;3&#xff09;list (const list& x) 拷贝构造函数&#xff08;4&#xff…

Spring Boot创建与运行

Spring Boot创建与运行 ​ 经过之前 Spring 文章的铺垫&#xff0c;终于来到了基于 Spring &#xff0c;并且也是 Spring 最火的框架之一 Spring Boot &#xff0c;在企业或者个人项目中&#xff0c;基本都是使用 Spring Boot &#xff0c;所以 Spring Boot 在 Spring 的学习阶…

Spring Boot 源码学习之@EnableAutoConfiguration注解

EnableAutoConfiguration 注解 引言主要内容1. EnableAutoConfiguration 功能解析1.1 常见的自动配置示例1.2 源码介绍 2. Import 注解介绍3. AutoConfigurationPackage 注解介绍 总结 引言 在 Huazie 的上篇博文中&#xff0c;我们详细了解了关于 SpringBootApplication 注解…

【论文阅读 03】机器学习算法在颈动脉斑块影像学分类中的研究进展

读完之后就是&#xff0c;总结 机器学习&#xff08;SVM、小波&#xff09;和深度学习&#xff08;CNN&#xff09;在 颈动脉斑块影像学中的 分类效果。只讨论了超声、磁共振两种成像 Chin J Clin Neurosci 临床神经科学杂志 复旦大学 颈动脉斑块( carotid plaques) 是一种…

JavaScript基础篇(31-40题)

此文章&#xff0c;来源于印客学院的资料【第一部分&#xff1a;基础篇(105题)】&#xff0c;也有一些从网上查找的补充。 这里只是分享&#xff0c;便于学习。 诸君可以根据自己实际情况&#xff0c;自行衡量&#xff0c;看看哪里需要加强。 概述如下&#xff1a; javascri…

使用Docker在局域网安装GitLab

使用 Docker 安装 GitLab 1. 安装GitLab 最近想在本地创建一个GitLab仓库&#xff0c;简单记录一下&#xff1a; 简单设置一个GitLab信息的存储目录 export GITLAB_HOME/etc/docker/gitlab/ && mkdir &GITLAB_HOMEdocker中启动 sudo docker run --detach \# 以…

C++:类和对象(上)---初步认识类和this指针

文章目录 面向过程和面向对象类的引入类的定义类定义的方式 类的访问限定符类的实例化类对象模型类对象的大小 this指针 面向过程和面向对象 C语言是一门面向过程的语言关注的是过程&#xff0c;确认一个问题求解的步骤&#xff0c;再一步一步对它进行解决 C是一门基于面向对…

【学会动态规划】最小路径和(9)

目录 动态规划怎么学&#xff1f; 1. 题目解析 2. 算法原理 1. 状态表示 2. 状态转移方程 3. 初始化 4. 填表顺序 5. 返回值 3. 代码编写 写在最后&#xff1a; 动态规划怎么学&#xff1f; 学习一个算法没有捷径&#xff0c;更何况是学习动态规划&#xff0c; 跟我…

Kotlin 协程基础入门:Channel(通道)

简介 Kotlin 中的 Channel&#xff08;通道&#xff09;是一种协程间通信的机制&#xff0c;用于在协程之间传递数据。它提供了一种有序、线程安全的方式&#xff0c;让生产者和消费者之间进行异步数据传输。 Channel 这个管道的其中一端&#xff0c;是发送方&#xff1b;管道…

OpenCV实现照片换底色处理

目录 1.导言 2.引言 3.代码分析 4.优化改进 5.总结 1.导言 在图像处理领域&#xff0c;OpenCV是一款强大而广泛应用的开源库&#xff0c;能够提供丰富的图像处理和计算机视觉功能。本篇博客将介绍如何利用Qt 编辑器调用OpenCV库对照片进行换底色处理&#xff0c;实现更加…

Promise 讲解,js知识,es6

文章目录 一、Promise的三种状态1. 初始态pending2. 成功态fulfilled&#xff0c;调用resolve方法3. 失败态rejected&#xff0c;调用reject方法 二、Promise的方法then方法catch方法 三、async和awaitasync 函数await 表达式 四、代码举例帮助理解1、Promise的值通过then方法获…

【idea】编译热部署

项目场景&#xff1a; 实际工作中&#xff0c;用到了idea&#xff0c;发现idea不编译代码&#xff0c;热部署什么的都不行 问题描述 在实际的工作中idea遇到了各种问题&#xff0c;之前一直用的2022版的&#xff0c;公司用的jboss起的项目&#xff0c;启动过程极其痛苦&#…

电子档案管理系统

电子文档 登陆成功后点击左上角“”选择“档案管理”跳转到“档案管理首页”如下图: 该界面列出用户被授权查看的可视化数据图形,柱图、饼图、线图、雷达图等,并结合数据仓库里的动态数据进行数据展现。 图形所展示的数据可根据企业需求定制,点击图形即可查看关联内容,方…

C++类与对象(上部曲)

目录 面向过程和面向对象初步认识 类的引入 类的定义 类的两种定义方式&#xff1a; 1. 声明和定义全部放在类体中 2. 类声明放在.h文件中&#xff0c;成员函数定义放在.cpp文件中 类的访问限定符及封装 1 访问限定符 2 封装 类的实例化 类对象的存储方式 this指针 …

IDEA快速创建SpringBoot

文件具有错误的版本 61.0, 应为 52.0报错可以看看是不是Springboot的版本比较高 和jdk版本不匹配 package com.qf.controller;import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframewor…

黑马 pink h5+css3+移动端前端

网页概念 网页是网站的一页,网页有很多元素组成,包括视频图片文字视频链接等等,以.htm和.html后缀结尾,俗称html文件 HTML 超文本标记语言,描述网页语言,不是编程语言,是标记语言,有标签组成 超文本指的是不光文本,还有图片视频等等标签 常用浏览器 firefox google safari…

从Vue2到Vue3【四】——Composition API(第四章)

系列文章目录 内容链接从Vue2到Vue3【零】Vue3简介从Vue2到Vue3【一】Composition API&#xff08;第一章&#xff09;从Vue2到Vue3【二】Composition API&#xff08;第二章&#xff09;从Vue2到Vue3【三】Composition API&#xff08;第三章&#xff09;从Vue2到Vue3【四】C…

os.environ[“CUDA_VISIBLE_DEVICES“]学习总结

今天发现一个很有意思的东西 import torch import os # Specify the GPU device os.environ["CUDA_VISIBLE_DEVICES"] "1" print(torch.cuda.is_available())但是如果修改下面的设置后&#xff0c;结果就变成了 import torch import os # Specify the…

【100天精通python】Day7:数据结构_列表 List的创建、删除、访问、遍历、统计、排序、推导等使用

目录 1 列表的创建 2 列表的删除 3 访问列表元素 4 遍历列表 5 添加修改删除列表元素 6 对列表进行统计和计算 7 对列表进行排序 8 列表推导式 9 多维列表 在Python中&#xff0c;列表是一种有序的可变数据类型&#xff0c;用于存储一组元素。 列表使用方括号“[] ”来…