- 相關推薦
C/C++變量在內存中的分布介紹
變量在內存地址的分布為:堆-棧-代碼區-全局靜態-常量數據。同一區域的各變量按聲明的順序在內存的中依次由低到高分配空間(只有未賦值的全局變量是個例外)。本文是百分網小編搜索整理的關于C/C++變量在內存中的分布介紹,感興趣的朋友一起學習吧!!想了解更多相關信息請持續關注我們應屆畢業生考試網!
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;
}
運行結果如下:
可以看出,主函數中棧的地址都要高于子函數中參數及棧地址,證明了棧的伸展方向是由高地址向低地址擴展的。主函數和子函數中靜態數據的地址也是相鄰的,說明程序會將已初始化的全局變量和靜態變量分配在一起,未初始化的全局變量和靜態變量分配在一起。
【C/C++變量在內存中的分布介紹】相關文章:
C/C++變量在內存中的分布05-03
C/C++內存管理05-05
C++類的成員變量和成員函數06-01
C語言變量存儲類別和內存四區04-15
如何在C/C++中調用Java03-13
C/C++中輸入多組數據方法02-09
C++中內聯函數的應用01-19