首页 / C++ / C/C++变量在内存中的分布
C/C++变量在内存中的分布
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了C/C++变量在内存中的分布,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3162字,纯文字阅读大概需要5分钟。
内容图文
![C/C++变量在内存中的分布](/upload/InfoBanner/zyjiaocheng/977/f7af698bdfad4f09b86d86781f178f51.jpg)
C/C++变量在内存中的分布在笔试时经常考到,虽然简单,但也容易忘记,因此在这作个总结,以加深印象。
先写一个测试程序:
#include <stdio.h>
#include <malloc.h>
int g_i = 100;
int g_j = 200;
int g_k, g_h;
int main()
{
const int MAXN = 100;
int *p = (int*)malloc(MAXN * sizeof(int));
static int s_i = 5;
static int s_j = 10;
static int s_k;
static int s_h;
int i = 5;
int j = 10;
int k = 20;
int f, h;
char *pstr1 = "MoreWindows123456789";
char *pstr2 = "MoreWindows123456789";
char *pstr3 = "Hello";
printf("堆中数据地址:0x%08x\n", p);
putchar('\n');
printf("栈中数据地址(有初值):0x%08x = %d\n", &i, i);
printf("栈中数据地址(有初值):0x%08x = %d\n", &j, j);
printf("栈中数据地址(有初值):0x%08x = %d\n", &k, k);
printf("栈中数据地址(无初值):0x%08x = %d\n", &f, f);
printf("栈中数据地址(无初值):0x%08x = %d\n", &h, h);
putchar('\n');
printf("静态数据地址(有初值):0x%08x = %d\n", &s_i, s_i);
printf("静态数据地址(有初值):0x%08x = %d\n", &s_j, s_j);
printf("静态数据地址(无初值):0x%08x = %d\n", &s_k, s_k);
printf("静态数据地址(无初值):0x%08x = %d\n", &s_h, s_h);
putchar('\n');
printf("全局数据地址(有初值):0x%08x = %d\n", &g_i, g_i);
printf("全局数据地址(有初值):0x%08x = %d\n", &g_j, g_j);
printf("全局数据地址(无初值):0x%08x = %d\n", &g_k, g_k);
printf("全局数据地址(无初值):0x%08x = %d\n", &g_h, g_h);
putchar('\n');
printf("字符串常量数据地址:0x%08x 指向 0x%08x 内容为-%s\n", &pstr1, pstr1, pstr1);
printf("字符串常量数据地址:0x%08x 指向 0x%08x 内容为-%s\n", &pstr2, pstr2, pstr2);
printf("字符串常量数据地址:0x%08x 指向 0x%08x 内容为-%s\n", &pstr3, pstr3, pstr3);
free(p);
return 0;
}
运行结果(Release版本,XP系统)如下:
可以看出:
1. 变量在内存地址的分布为:堆-栈-代码区-全局静态-常量数据
2. 同一区域的各变量按声明的顺序在内存的中依次由低到高分配空间(只有未赋值的全局变量是个例外)。
3. 全局变量和静态变量如果不赋值,默认为0。 栈中的变量如果不赋值,则是一个随机的数据。
4. 编译器会认为全局变量和静态变量是等同的,已初始化的全局变量和静态变量分配在一起,未初始化的全局变量和静态变量分配在另一起。
上面程序全在一个主函数中,下面增加函数调用,看看函数的参数和函数中变量会分配在什么地方。
程序如下:
#include <stdio.h>
void fun(int i)
{
int j = i;
static int s_i = 100;
static int s_j;
printf("子函数的参数: 0x%p = %d\n", &i, i);
printf("子函数 栈中数据地址: 0x%p = %d\n", &j, j);
printf("子函数 静态数据地址(有初值): 0x%p = %d\n", &s_i, s_i);
printf("子函数 静态数据地址(无初值): 0x%p = %d\n", &s_j, s_j);
}
int main()
{
int i = 5;
static int s_i = 100;
static int s_j;
printf("主函数 栈中数据地址: 0x%p = %d\n", &i, i);
printf("主函数 静态数据地址(有初值): 0x%p = %d\n", &s_i, s_i);
printf("子函数 静态数据地址(无初值): 0x%p = %d\n", &s_j, s_j);
putchar('\n');
fun(i);
return 0;
}
运行结果如下:
可以看出,主函数中栈的地址都要高于子函数中参数及栈地址,证明了栈的伸展方向是由高地址向低地址扩展的。主函数和子函数中静态数据的地址也是相邻的,说明程序会将已初始化的全局变量和表态变量分配在一起,未初始化的全局变量和表态变量分配在另一起。
转载请标明出处,原文地址:http://blog.csdn.net/morewindows/article/details/6851681
再分享一下我老师大神的人工智能教程吧。零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到我们人工智能的队伍中来!https://www.cnblogs.com/captainbed
内容总结
以上是互联网集市为您收集整理的C/C++变量在内存中的分布全部内容,希望文章能够帮你解决C/C++变量在内存中的分布所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。