首页
题库
公司真题
专项练习
面试题库
在线编程
面试
面试经验
AI 模拟面试
简历
求职
学习
基础学习课
实战项目课
求职辅导课
专栏&文章
竞赛
我要招人
发布职位
发布职位、邀约牛人
更多企业解决方案
AI面试、笔试、校招、雇品
HR免费试用AI面试
最新面试提效必备
登录
/
注册
负能量迪不要
门头沟学院 C++
发布于陕西
关注
已关注
取消关注
@Dreams0000:
🍎06-C++面试之STL内存管理篇
[toc]0 前述针对于自己在秋招的面试中,对于CPP部分遇到的问题,其中大部分是以此为起点,你可以基于这些点,将自己对于CPP学习的知识点,串联起来。无论面试官,问这一类问题中的某个点,你都应该可以将这一个珠子串联到自己的知识链上来讲。这是一种拓展知识的能力。在此专栏下面个人校招记录:回馈牛客,对CPP做一个小小的总结。本部分关于CPP的STL的内存管理方式的点来展开即可,分别讨论普通的内存管理方式和STL的内存管理方式,以及STL内存管理方式本身的可改善的点。下面对应的是之前发布的个人校招其他公司面试总结,希望可以更好的帮到你✍✍总结:以代码的方式回看自己23届校招 | 或恐慌、疑惑、好在坚持!🌋大疆DJI 嵌入式 ✨MINIEYE自动驾驶 软开 深圳 实习 🌟百度 嵌入式软开 上海 2022.07🌳深圳杰理科技嵌入式 2022.07.26🌵深圳 诺瓦星云提前批 嵌入式 2022.08.06🌴哲库科技 提前批 2022.08.07🌲经纬恒润 自动驾驶嵌入式 1,2面 2022.08.15😥丰疆智能 嵌入式软开 1,2,3面+4面 2022.08.09🤷♂️一次让我略感疲惫的英文面试--吉利极氪 嵌入式软开🙆♂️♂️【深信服校招】笔试+面试 软件开发工程师🌾ZTE中兴软件工程师 一面+二面 2022.08.29🌱紫光同芯 嵌入式软开 芯片 2022.09.19🌄美团校招面经 嵌入式 1,2面 2022. 09🎋360 软开 一面+二面+ 2022.09这里是`CPP一些面试问题整理🥭01-C++面试之C++11新特性总结🍏02-C++面试之static关键字🍑03-C++面试之四种强制类型转换🍋04-C++面试之析构函数和构造函数🍐05-C++面试之多态底层实现:虚表和虚表指针🍎06-C++面试之STL内存管理篇🍅07-C++面试之从代码到可执行程序经历……未完待续1 普通的内存管理方式我们知道动态开辟内存是,要在堆上申请;1)如果说需要的频繁的话,就需要一次次在堆上开辟和释放内存,并且会造成内存碎片化,浪费内存空间(在申请一整个大块内存空间的时候,都是不连续的小碎片);2)且每次申请都要进行调用malloc和free操作,造成配置时的一些额外负担。以此,以效率著称的STL库,提出两级空间配置器。1)当一次申请的内存够大,超过128bytes时,就移交给第一级配置器处理,就是直接new和delete出一块大内存;2)当一次申请的空间小于128bytes,就使用二级配置器以内存池的形式进行管理。内存池的一个显著优点就是尽量避免内存碎片,使得内存分配效率得到提升。2 STL内存管理方式整体形式,维护16条free-list,对应各大小的内存块,从0~15号,内存最小8bytes,以8bytes逐渐递增,最大128bytes。传入的参数会自动将内存需求量上调至8的倍数(比如客户端需要30bytes,这边就自动商调至32bytes),找到32bytes所对应的内存大小的链表;查看是否为空,不为空的话就直接从该链表中取出一个分配给该请求,再将对应链表的指针向后移动一位。若对应的链表为空的话,进一步,先看看内存池是不是空的,不空,就从内存池里面分配1)先检查内存池剩余空间,够不够20个(默认)这样的(32bytes大小)的空间,若足够就直接拿出,将一个分配出去,剩下的挂载对应的free-list下,等待下次分配。2)如果不够20个大小,看够不够1个,够1个就先直接分配出去。再更新free-list,将内存池剩余的空间分配尽可能多的节点挂在其他free-list上面。3)若果池子剩余的空间一个都满足不了的话,先将内存池中剩余的空间挂在相应小内存的free-list上,然后,找老大"系统"😎给内存池分配空间。内存池空的话1)给内存池申请内存,使用malloc()从heap上申请内存(一次申请的内存大小为= 2*所需节点内存(8的倍数) * 20个 + 一段额外的空间),大约申请40块,一半拿来用,放在free-list上面;一般放在内存池中。 😯一个奇怪的提问:为什么会是乘以2的操作,就和vector,在存放满的时候,进行扩充一样,为什么是2倍,不是1.5倍这样的扩充:(曾经有个面试官这样问过)答:目前看来大致是,2对于计算机来说比较好处理一些,二进制直接使用10即可表示出来。2)假若系统中没有malloc出来,说明heap(系统)上也没有内存了,那就从其他大的free-list上借一个节点使用。如果系统上也没有找到,那就只能调用一级配置器。3 STL的一些缺点自由链表的管理问题,把所需要申请的内存自动调整到8的倍数。比如,你需要申请1个字节的话,也就给你8bytes,浪费,久而久之,也会造成内部碎片的问题。内存的使用过程中,所申请的内存会一块块挂在free-list上面,也不会还给操作系统,申请的内存只有在当前进程结束的时候,才会释放内存。1)开辟小内存开辟的太多,导致申请大内存的时候,就容易失败;2)申请的内存太多,不归还,别的进程想用但是没有,会引发问题。
点赞 3
评论 1
全部评论
推荐
最新
楼层
暂无评论,快来抢首评~
相关推荐
不愿透露姓名的神秘牛友
昨天 18:00
求助!mt不给本部转正机会,我要润吗?
rt,主包正在腾讯暑期实习mt说我达不到本部正职的level,给了个腾娱的转正这种情况是苟着拿腾娱offer?保底还是当场离职全力秋招啊?
投递腾讯等公司10个岗位
点赞
评论
收藏
分享
07-31 16:02
韶音科技_产品经理(准入职员工)
韶音科技内推
2024-06-08,投递简历:提前批-机械结构工程师2024-06-30,专业笔试:使用的牛客题库,20道选择题+2道简答题,考察范围包括机设、机原、材料、力学、工艺等2024-07-24,HR面试邀约2024-08-02,HR面试,腾讯会议,约20min。面试流程如下: 1. 自我介绍 2. 人事问答: (1)你的研究方向?你们课题组的研究方向有哪些? (2)分工? (3)项目简述:项目背景?解决什么问题?你做了哪些工作?结构怎样设计的?工作过程中有探索性学习?动手实践吗?项目进展? (4)实验室有多少人? (5)博士有吗? (6)做项目会有...
点赞
评论
收藏
分享
07-13 21:50
门头沟学院 Java
实习包装太狠了..
各位牛爷爷看看我的实习是不是包装太狠了
点赞
评论
收藏
分享
06-26 21:09
长沙理工大学 C++
有没有人来制裁一下
如下图,真让我惊到了,有没有人去给这老板上一课
写不来代码的小黑:
这么小的城市能有做it的公司也不容易
点赞
评论
收藏
分享
07-31 17:54
大连海事大学 网络安全
面试官这是啥意思?
不多说了,看图吧
MomonKa:
实际上是,机房机器有些高度,问问你身高,有没有女朋友是看你能不能猛猛加班
你最讨厌面试问你什么?
点赞
评论
收藏
分享
评论
点赞成功,聊一聊 >
点赞
收藏
分享
评论
提到的真题
返回内容
全站热榜
更多
1
...
都是 dirty work,为什么别人的简历上就能言之有物🤔
2.1W
2
...
虾皮秋招一面
4397
3
...
虾皮后端一面(已挂)
4370
4
...
百度提前批,三面被推迟一周,喜提秋招第一凉
3758
5
...
7.30滴滴提前批一面凉经
3478
6
...
百度提前批 三面
3329
7
...
干活最少的实习生因为长得漂亮转正了
3075
8
...
他拿大厂SSP Offer打牌是什么概念啊?25届双非之光
2923
9
...
7.30百度提前批一面
2580
10
...
QQ提前批一面凉经
2573
创作者周榜
更多
正在热议
更多
#
你遇到最难的面试题目是_
#
15353次浏览
194人参与
#
反问环节如何提问
#
95577次浏览
1951人参与
#
中兴秋招
#
203955次浏览
2282人参与
#
简历上的经历如何包装
#
24729次浏览
731人参与
#
如何看待offer收割机的行为
#
815701次浏览
6088人参与
#
你最讨厌面试问你什么?
#
25411次浏览
286人参与
#
秋招最大的收获是什么?
#
38653次浏览
323人参与
#
我的实习收获
#
90944次浏览
1039人参与
#
26届的你,投了哪些公司?
#
37571次浏览
434人参与
#
滴滴求职进展汇总
#
233397次浏览
2116人参与
#
作业帮求职进展汇总
#
57041次浏览
376人参与
#
初创公司值得加入吗?
#
27357次浏览
194人参与
#
我对___祛魅了
#
43796次浏览
410人参与
#
数字马力求职进展汇总
#
184483次浏览
1500人参与
#
你跟室友的关系怎么样?
#
6173次浏览
94人参与
#
什么样的背景能拿SSP?
#
31905次浏览
207人参与
#
工作中哪个瞬间让你想离职
#
60883次浏览
548人参与
#
和同事相处最忌讳的是__
#
21405次浏览
217人参与
#
去年你投递实习了吗?
#
22894次浏览
331人参与
#
如何快速融入团队?
#
15039次浏览
182人参与
#
机械人的金三校招总结
#
36276次浏览
461人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务