嵌入式面经

1.(内存)堆和栈的区别⭐
堆栈空间分配不同:
栈由操作系统自动进行分配和释放,用于存放函数的参数值、局部变量的值等,具有高效性。
堆一般由程序员手动进行分配和释放,效率比栈低很多。
堆栈缓存方式不同:

栈使用一级缓存,存储在处理器核心中,调用完成后立即释放,速度较快。
堆存储在二级缓存或主存中,速度相对较慢。
生长方向:

堆:堆的分配方向是向上的,即向地址较大的方向分配。当堆需要扩展时,会向高地址方向增长。
栈:栈的分配方向是向下的,即向地址较小的方向分配。当栈需要扩展时,会向低地址方向增长。
生命周期:

堆:堆上的内存在分配时并不会被立即释放,需要手动进行内存释放操作。堆上的数据可以在程序的任意位置进行访问,不受函数的调用关系限制。
栈:栈上的内存分配和释放是自动进行的,随着函数的调用和返回进行相应的操作。栈上的数据只在特定的作用域内有效,函数执行完成后会自动释放。
空间大小:

栈的空间大小一般较小,通常最多为2MB,超过则会报溢出错误。
堆的空间比较大,理论上可以接近3GB(对于32位程序来说)。
能否产生碎片:
2.在函数中申请堆内存需要注意什么⭐
确保不要错误地返回指向栈内存的指针,因为栈内存会在函数结束时自动释放。
避免在函数内部申请临时数组,因为函数执行完成后,该数组会消失。
不要返回指向常量区的内存空间,因为它们无法修改且获取它们没有意义。
使用传入一级指针无法解决问题,因为函数内部指针的修改不会影响传入的指针。
在分配堆内存时,确保空间足够存储所需数据,避免访问越界和产生未定义行为。
解决办法如下:

使用二级指针来返回申请的堆内存的地址,通过间接引用来修改指针值,从而确保在函数外部能够获取到堆内存的内容。
使用指针函数来解决问题,即返回通过malloc函数申请的堆内存的地址,这样可以在函数外部使用free函数释放该内存。
3.请你说说内存碎片⭐
内存碎片是指在内存管理过程中产生的未被有效利用的零散、不连续的内存空间。主要分为两种类型:内部碎片和外部碎片。

内部碎片:是由于固定大小的内存分配方式或对齐要求等原因导致的未被利用的小空间。当分配给进程的内存块大于所需的大小时,其中的剩余空间就成为了内部碎片。
外部碎片:是由于存在未分配的连续内存空间太小而不能满足分配请求,从而导致这些内存无法被有效利用。
解决内存碎片问题的方法可以包括:
全部评论
关注我,分享更多嵌入式面试知识
1 回复 分享
发布于 2023-10-24 22:18 北京

相关推荐

08-14 11:39
门头沟学院 Java
点赞 评论 收藏
分享
投递OPPO等公司10个岗位
点赞 评论 收藏
分享
现在回看难度也是很小的一场面试,可惜当时啥都没学。面试公司:禾赛科技。面试岗位:嵌入式软件开发实习生。面试时间:2024.5.23 视频面,40min左右面试问题:自我介绍。串口通信的协议,波特率如何计算,波特率不一致的话通信会有什么影响。IIC协议,有应答信号吗,最多可以接几个从机。SPI协议,四种时序的区别。malloc和calloc的区别。UDP和TCP的区别。三次握手和四次挥手的过程。拥塞控制算法。代码到可执行程序的流程,每一步gcc的参数(比如怎么得到汇编代码)。静态库和动态库的区别。手撕两数相加(LeetCode2,就在网页做)。面试体验:其实可以看到禾赛对实习生要求还是较低的(但学历可能卡的比较死),基本都是一些基础的问题,涉及的内容也是C语言、单片机、操作系统、计算机网络、数据结构和算法等基本技能。但当时实习准备的太不充分了,且当时项目经历也很简单,最后给的感觉就是基础不太好。全球激光雷达Top禾赛科技26届校招提前批火热进行中【企业介绍】全球领先的激光雷达研发与制造企业,全球激光雷达市占率No.1,美国纳斯达克上市。【开放岗位】商务类、产品类、项目管理类、销售类、系统类、芯片类、光学类、机械类、电子类、软件类、算法类、测试类、制造类【工作地点】上海、杭州【薪资福利】行业 TOP 级薪酬+丰富激励奖金+股票期权福利+女性友好+14 天带薪年假+优先落户+医疗保险等等【内推链接】https://kwh0jtf778.jobs.feishu.cn/229043/m/?external_referral_code=TR9CYWP
点赞 评论 收藏
分享
评论
7
39
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务