首页
题库
公司真题
专项练习
面试题库
在线编程
面试
面试经验
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
全部评论
推荐
最新
楼层
暂无评论,快来抢首评~
相关推荐
昨天 11:50
门头沟学院 产品经理
小米到底什么时候能翻我牌子
做完笔试一直没有进展,有没有懂得佬
投递小米集团等公司10个岗位
点赞
评论
收藏
分享
08-13 14:15
上海大学 运营
没被秒挂真是快哉快哉
周六投的,周一一上班就挂我
点赞
评论
收藏
分享
07-31 14:40
门头沟学院 Java
人机hr
申转人工
牛客39712426...:
触发重传机制了,可能是服务器负载太高了,ACK丢包了
找工作时遇到的神仙HR
点赞
评论
收藏
分享
08-10 12:43
临沂大学 Java
27届简历求拷打
lz现在准大三,准备大三开学去找实习,现在在根据这个简历背八股,简历是仿照别人然后自己稍微修改了一下,求大佬指点指点
点赞
评论
收藏
分享
昨天 11:25
武汉理工大学 新材料/环保技术
oppo进面了竟然
笔试一道题都不会差不多十分钟选完了居然也能进面!!!
OPPO一面271人在聊
点赞
评论
收藏
分享
评论
点赞成功,聊一聊 >
点赞
收藏
分享
评论
提到的真题
返回内容
全站热榜
更多
1
...
总结常用的拖offer的几种话术
2.8W
2
...
8月份面经整理的算法高频题集合
7007
3
...
美团二笔还没发邮件
6423
4
...
实习生不能抢红包吗?
4601
5
...
快手秋招-后端一面
3548
6
...
8.13快手秋招Java后端二面记录
3464
7
...
快手 秋招 一面
3411
8
...
家里人一直跟我说要给领导买点东西,搞好关系
3364
9
...
大家离职都怎么开口的啊?
3007
10
...
救救孩子吧
3007
创作者周榜
更多
正在热议
更多
#
给26届的秋招建议
#
29789次浏览
827人参与
#
应届生初入职场,求建议
#
239139次浏览
2683人参与
#
实习的内耗时刻
#
45515次浏览
529人参与
#
发工资后,你做的第一件事是什么
#
71782次浏览
241人参与
#
工作上你捅过哪些篓子?
#
18443次浏览
121人参与
#
在职场上,你最讨厌什么样的同事
#
27263次浏览
193人参与
#
秋招投递记录
#
26646次浏览
300人参与
#
我的秋招“寄”录
#
37690次浏览
485人参与
#
你最近一次加班是什么时候?
#
79518次浏览
422人参与
#
秋招,不懂就问
#
10417次浏览
112人参与
#
网易求职进展汇总
#
112779次浏览
1063人参与
#
查收我的offer竞争力报告
#
195614次浏览
1291人参与
#
我的国央企投递进展
#
51814次浏览
312人参与
#
我的AI电子员工
#
12739次浏览
103人参与
#
独居后,你的生活是更好了还是更差了?
#
12072次浏览
167人参与
#
如果校招重来我最想改变的是
#
278264次浏览
2896人参与
#
你上一次给父母打电话是什么时候
#
11741次浏览
111人参与
#
规定下班时间vs实际下班时间
#
19391次浏览
152人参与
#
运营每日一题
#
90494次浏览
798人参与
#
如果你有一天可以担任公司的CEO,你会做哪三件事?
#
32365次浏览
488人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务