arm学习笔记--程序中变量引起的思考
/*这一块是跑飞的代码*/
uint32_t UserCode[244];
UserCode[0]=1;
/*代码over*/
1、由于局部变量创建的时候是静态创建在栈上的,所以栈的大小限制了局部变量的size,如果栈小了,在运行的时候就会出现溢出,程序当然就飞了。这里就有概念上的疑问了:静态创建和动态创建区别是什么?局部变量占用的是栈的空间,那么其他类型的变量呢?下面我们就来看这个问题。
2、静态创建和动态创建的区别
我个人的理解:静态创建分为两个部分,一个是编译时,这个时候我们定义的静态变量和全局变量将在自动划分内存空间;一个是在运行时,就是局部变量,在栈区生成一个固定大小的空间;为什么说他是静态的呢?因为这些变量或数组空间的大小我们是预先可知的。而动态创建呢?我们使用malloc和free创建和释放内存空间,他们的大小是按需分配,所以是动态创建,是在堆上分配的。
3、变量类型分为:局部变量,静态局部变量,全局变量,静态全局变量。他们在存储上可以根据创建的方式进行分析,静态和全局都是在编译是进行创建的,所以是在普通的内存区域,局部变量是在运行时创建的,在栈上,但是栈上的空间和普通内存区域有没有重复呢?这个目前我还不清楚,还需要继续加深理解。在作用域上:局部变量在调用函数的时候创建,返回的时候系统自己进行销毁;全局变量可以在工程的所有单元文件下使用;静态全局变量只能在当前单元文件下使用;静态局部变量,只创建一次,函数返回的时候不对他进行任何操作,所以下次进函数的时候他保留的是上一次的值,不会清除。
4、堆和栈的区别:堆用于动态分配空间等,由程序员创建和操作;栈是由编译器自动分配的,主要用于存放函数的参数值和局部变量。平时说的函数调用或中断入栈等等都是指的这里编译器分配的栈。
好,现在我们回到刚刚的出现问题的代码上来,然后我们看看怎么解决,由于分析出是栈不够的情况,所以我们就可以通过其他两种方式解决:
1、改变变量数组类型:全局或静态的,这样由编译器分配内存
2、使用malloc动态分配空间:由于malloc不占用栈区,所以也可以我们先改为全局变量试试
arm程序变 相关文章:
- Windows CE 进程、线程和内存管理(11-09)
- RedHatLinux新手入门教程(5)(11-12)
- uClinux介绍(11-09)
- openwebmailV1.60安装教学(11-12)
- Linux嵌入式系统开发平台选型探讨(11-09)
- Windows CE 进程、线程和内存管理(二)(11-09)