您的位置 首页 测评

stm32内存分配

(1)栈区(stack):由编译器自动分配和释放,存放函数的参数值、局部变量的值等,其操作方式类似于数据结构中的栈。(2)堆区(heap):

(1)栈区(stack):由编译器主动分配和开释,寄存函数的参数值、局部变量的值等,其操作方法相似

于数据结构中的栈。

(2)堆区(heap):一般由程序员分配和开释,若程序员不开释,程序完毕时或许由操作系统收回。分配

方法相似于数据结构中的链表。

(3)大局区(静态区)(static):大局变量和静态变量的存储是放在一块的,初始化的大局变量和静态

变量在一块区域,未初始化的大局变量和未初始化的静态变量在相邻的另一块区域。程序完毕后由系

统主动开释。

(4)文字常量区:常量字符串便是寄存在这里的。

(5)程序代码区:寄存函数体的二进制代码。

例如:

int a=0;//大局初始化区

char *p1;//大局未初始化区

main()

{

int b;//栈

char s[]=”abc”;//栈

char *p3= “1234567”;//在文字常量区

static int c =0 ;//静态初始化区

p1= (char *)malloc(10);//堆区

strcpy(p1,”123456″);//”123456″放在常量区

}

所以堆和栈的差异:

stack的空间由操作系统主动分配/开释,heap上的空间手动分配/开释。

stack的空间有限,heap是很大的自在存储区。

程序在编译期和函数分配内存都是在栈进步行,且程序运转中函数调用时参数的传递也是在栈进步

行。

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/ceping/256006.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部