数据在内存中的存储 http://www.cnblogs.com/xiu619544553/p/5325177.html
数据在内存中的存储
不同类型的数据,在内存中的存储区域不同:
1. 栈区stack:存放函数的参数值、局部变量的值。由编译器自动分配、释放。其操作方式类似于数据结构中的栈。
2. 堆区heap:一般由程序员分配、释放。如果程序员不释放,那么程序结束时可能由操作系统回收。分配方式类似于数据结构中的链表。
3. 全局区(静态区):全局变量和静态变量的存储是放在一块的,初始化的全局变量和静态变量在一块,未初始化的全局变量和未初始化的静态变量在相邻的另一块区域。程序结束后由系统释放。
4. 文字常量区:存放常量字符串。程序结束后由系统释放。
5. 程序代码区:存放函数体的二进制代码。
6. 寄存区:用来存放栈顶指针和指令指针(汇编操作)。
例子:
1 int a = 0; // 全局初始化区
2 char *p1; // 全局未初始化区
3
4 int main(void) {
5 int e; // 栈区
6 char d[] = "Kingdev"; // 栈区
7 char *p2; // 栈区
8 char *p3 = "98765"; // 98765/0 在常量区,p3在栈区
9 static int c = 0; // 全局区[静态区]
10 strcpy(p1, "98765"); // 98765/0 放在常量区,编译器可能会将它与p3所指向的“98765”优化成一个地方。
11 p1 = (char *)malloc(10); // 分配得来得10字节的区域就在堆区
12 p2 = (char *)malloc(20); // 分配得来得20字节的区域就在堆区
13 }
数据在内存中的存储
不同类型的数据,在内存中的存储区域不同:
1. 栈区stack:存放函数的参数值、局部变量的值。由编译器自动分配、释放。其操作方式类似于数据结构中的栈。
2. 堆区heap:一般由程序员分配、释放。如果程序员不释放,那么程序结束时可能由操作系统回收。分配方式类似于数据结构中的链表。
3. 全局区(静态区):全局变量和静态变量的存储是放在一块的,初始化的全局变量和静态变量在一块,未初始化的全局变量和未初始化的静态变量在相邻的另一块区域。程序结束后由系统释放。
4. 文字常量区:存放常量字符串。程序结束后由系统释放。
5. 程序代码区:存放函数体的二进制代码。
6. 寄存区:用来存放栈顶指针和指令指针(汇编操作)。
例子:
1 int a = 0; // 全局初始化区
2 char *p1; // 全局未初始化区
3
4 int main(void) {
5 int e; // 栈区
6 char d[] = "Kingdev"; // 栈区
7 char *p2; // 栈区
8 char *p3 = "98765"; // 98765/0 在常量区,p3在栈区
9 static int c = 0; // 全局区[静态区]
10 strcpy(p1, "98765"); // 98765/0 放在常量区,编译器可能会将它与p3所指向的“98765”优化成一个地方。
11 p1 = (char *)malloc(10); // 分配得来得10字节的区域就在堆区
12 p2 = (char *)malloc(20); // 分配得来得20字节的区域就在堆区
13 }