嵌入式面经

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

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

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

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

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

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

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

相关推荐

7 38 评论
分享
牛客网
牛客企业服务