C++面试八股文:聊一聊指针?
某日二师兄参加XXX科技公司的C++工程师开发岗位第17面:
面试官:聊一聊指针?
二师兄:好的。
面试官:你觉得指针本质上是什么?
二师兄:这要从内存地址开始说起了。如果有一块容量是1G的内存,假设它的地址是从
0x00000000
到0x3fffffff
,每一个字节都对应一个地址。当我们声明一个变量并初始化它时:
int a = 42;
二师兄:操作系统会分配一块容量为
4(sizeof(int))
的地址,这块内存的首地址是0x00001000
(假设),结束地址是0x00001003
,在申请的这4
个字节上放入42
。当我们对这个变量取地址时,
int a = 42;
int* p = &a;
二师兄:操作系统会再分配一块内存,这块内存的大小是
sizeof(int*)
,这块内存的起始地址是0x00002000
(假设),结束地址是0x00002003
(32位操作系统),然后将&a
取到的起始地址0x00001000
放入0x00002000
-0x00002003
中。并将刚分配的这块内存的起始地址赋给p
。
二师兄:当我们对
p
操作时,是对0x00002000-0x00002003
这块内存操作,当我们对*p
(解引用)操作时,是对0x00001000-0x00001003
这块内存操作。二师兄:回到问题,我觉得指针的本质就是内存地址。虽然指针指向一块内存地址,但它同时也是一个变量,也可以对指针取地址。如果对指针取地址,同样可以得到一个内存地址(如
0x00002000
),如果把这个内存地址存起来,那么指向这个内存地址的变量的类型就是二级指针(int**
)。面试官:好的。在
0x00002000-0x00002003
这块内存中,我们放入了一个地址是0x00001000
,但是并没有这个地址的长度。只知道一个地址而不知道长度,怎么能把数据取出来?二师兄:这主要是因为
p
的类型是int*
,当对p
解引用时,编译器知道了解引用的结果是int
类型,所以从0x00001000
往后读取4个字节(sizeof(int)
),并按照当前CPU的模式(考虑大小端)把这四个字节组成一个int
类型的变量。面试官:
malloc
函数你知道吧,返回的类型是void*
,在free
的时候怎么知道这块内存的大小的呢?二师兄:额。。这个还不太清楚。。
面试官:没关系,今天就到这里,回去等通知吧。
让我们来看看让二师兄折戟的这个问题:
malloc
函数返回的类型是void*
,在free
的时候怎么知道这块内存的大小的呢?
这里牵扯到malloc
和free
的实现方式,不同的厂商实现的方式不尽相同。以ptmalloc
为例,当使用malloc
申请size = 16
的内存时,malloc
会从内存池中分配一块sizeof(chunk)+16
长度的内存。chunk
段保存了一些前后chunk
的信息,也保存了这块内存的大小(16)。malloc
函数返回的地址是0x00001000
,而在free(0x00001000)
时,free
函数会用0x00001000
减去特定值(sizeof(chunk)
),得到chunk
的起始地址,从chunk
中获取这块内存真正的尺寸,从而完成free
的任务。抛开内存的利用率不说,这是一个非常美妙的实现!
好了,今日份面试到这里就结束了。关注我,每天带你学习一个C++小知识!
关注我,带你21天“精通”C++!(狗头)
C++面试八股文:聊一聊指针?的更多相关文章
- 《面试八股文》之 JVM 20卷
微信公众号:moon聊技术 关注选择" 星标 ", 重磅干货,第一 时间送达! [如果你觉得文章对你有帮助,欢迎关注,在看,点赞,转发] 大家好,我是 moon. <面试八股 ...
- 《面试八股文》之kafka21卷
微信公众号:moon聊技术 关注选择" 星标 ", 重磅干货,第一 时间送达! [如果你觉得文章对你有帮助,欢迎关注,在看,点赞,转发] 大家好,我是moon,最新一篇面试八股文系 ...
- 《面试八股文》之 Redis 16卷
微信公众号:moon聊技术 关注选择" 星标 ", 重磅干货,第一 时间送达! [如果你觉得文章对你有帮助,欢迎关注,在看,点赞,转发] 大家好,我是 moon. redis 作为 ...
- 面试官: 聊一聊Babel
点击关注本公众号获取文档最新更新,并可以领取配套于本指南的 <前端面试手册> 以及最标准的简历模板. 前言 Babel 是现代 JavaScript 语法转换器,几乎在任何现代前端项目中都 ...
- C语言面试题目之指针和数组
说明:所有题目均摘录于网络以及我所见过的面试题目,欢迎补充! 无特殊说明情况下,下面所有题s目都是linux下的32位C程序. 先来几个简单的热热身. 1.计算以下sizeof的值. char str ...
- 这可能是最全面的TCP面试八股文了
计算机网络基础,考验一个程序员的基本功,也能更快的筛选出更优秀的人才. 说说TCP的三次握手 假设发送端为客户端,接收端为服务端.开始时客户端和服务端的状态都是CLOSED. 第一次握手:客户端向服务 ...
- 一天吃透MySQL面试八股文
什么是MySQL MySQL是一个关系型数据库,它采用表的形式来存储数据.你可以理解成是Excel表格,既然是表的形式存储数据,就有表结构(行和列).行代表每一行数据,列代表该行中的每个值.列上的值是 ...
- 一天吃透JVM面试八股文
什么是JVM? JVM,全称Java Virtual Machine(Java虚拟机),是通过在实际的计算机上仿真模拟各种计算机功能来实现的.由一套字节码指令集.一组寄存器.一个栈.一个垃圾回收堆和一 ...
- 这可能是最全面的MySQL面试八股文了
什么是MySQL MySQL是一个关系型数据库,它采用表的形式来存储数据.你可以理解成是Excel表格,既然是表的形式存储数据,就有表结构(行和列).行代表每一行数据,列代表该行中的每个值.列上的值是 ...
- java数据结构面试问题—快慢指针问题
上次我们学习了环形链表的数据结构,那么接下来我们来一起看看下面的问题, 判断一个单向链表是否是环形链表? 看到这个问题,有人就提出了进行遍历链表,记住第一元素,当我们遍历后元素再次出现则是说明是环形链 ...
随机推荐
- PyCharm解决Git冲突
技术背景 在前面的一篇博客中,我们介绍了Fork到自己名下的本地仓库如何与远程原始仓库创建链接的方法.在这篇文章中,我们将要讲解如何应对在这种异步开发的过程中经常有可能会遇到的Git冲突问题,在Pyc ...
- 【Vue原理模拟】模拟Vue实现响应式数据
1. 预期效果 当数据变动时,触发自定义的回调函数. 2. 思路 对对象 object 的 setter 进行设置,使 setter 在赋值之后执行回调函数 callback(). 3.细节 3.1 ...
- LeetCode 双周赛 101,DP/中心位贪心/裴蜀定理/Dijkstra/最小环
本文已收录到 AndroidFamily,技术和职场问题,请关注公众号 [彭旭锐] 提问. 大家好,我是小彭. 这周比较忙,上周末的双周赛题解现在才更新,虽迟但到哈.上周末这场是 LeetCode 第 ...
- Java设计模式 —— 观察者模式
16 观察者模式 16.1 观察者模式概述 Observer Pattern: 定义对象之间的依赖关系(一对多),当一个对象的状态发生改变时,其关联的依赖对象均收到通知并自动更新. 观察者模式又称:发 ...
- day118:MoFang:根据激活/未激活的状态分别显示树桩&种植植物&解锁树桩&化肥/修剪/浇水/宠物粮小图标数字的显示
登录 1.根据激活状态和未激活状态分别显示树桩 2.用户使用植物道具进行果树种植 3.解锁树桩 4.化肥/修剪/浇水/宠物粮小图标显示 种植栏的功能实现 1. 客户端需要的植物相关参数: 总树桩数量, ...
- el-menu使用递归组件实现多级菜单组件
1. 效果: 2. 实现: 创建外层菜单AsideMenu.vue组件和子菜单项AsideSubMenu.vue组件,在AsideSubMenu中进行递归操作. AsideMenu.vue文件内容如下 ...
- linux 安装 node 和 npm 服务
1.安装文件下载 下载地址:https://nodejs.org/zh-cn/download/ 2.安装步骤 1.将安装包上传到指定位置(我习惯放到:/usr/local/application/目 ...
- MySQL(三)数据目录
目录 Mysql的主要目录结构 1 数据库文件的存放路径 /var/lib/mysql/ 2 相关命令目录 /usr/bin/mysql /usr/sbin/mysql 3 配置文件目录 /usr/s ...
- 实例讲解Playwright(一)
实例讲解Playwright(一) 网址 说明 https://playwright.dev/ 官网首页 https://playwright.dev/python/docs/intro Python ...
- axios文件下载!!!!
前端 download(){ debugger; this.loading = true; axios.post('http://localhost:8081/brand_case/dao.do?me ...