在我的程序中,我声明了一个初始化的全局变量(作为数组).但它只影响可执行文件的大小,程序的内存使用量不受影响.
我的程序就是这样
char arr[1014*1024*100] = {1};
int _tmain(int argc, _TCHAR* argv[])
{
while (true)
{
}
return 0;
}
Run Code Online (Sandbox Code Playgroud)
可执行文件的大小为118MB,但运行程序时的内存使用量仅为0.3MB
有人能为我解释一下吗?
大多数操作系统使用按需分页的虚拟内存.
这意味着当您加载程序时,该程序的可执行文件不允许立即加载到内存中.而是设置虚拟内存页面以将文件映射到内存.何时(以及如果)实际引用地址会导致页面错误,操作系统随后通过将文件的相应部分读入物理内存来处理,然后让指令重新执行.
在您的情况下,您没有参考arr,因此操作系统永远不会将该数据拉入内存.
如果您要查看程序使用的虚拟地址空间(而不是您现在正在查看的物理内存),您可能会看到为所有人分配的地址空间arr.虽然虚拟地址空间通常不是非常有趣或有用,但是大多数告诉您内存使用情况的事情只会告诉您用于存储实际数据的物理RAM,而不是分配但从未使用过的虚拟地址空间.
即使您确实参考了数据,操作系统也可能相当聪明:根据您引用数据的频率(以及是否修改数据),在任何给定时间只能将部分数据加载到RAM中.如果它被修改,可以将修改后的部分写入页面文件,以便在RAM中为更频繁使用的数据腾出空间.如果它没有被修改,它可以被丢弃(因为原始数据可以在需要时从磁盘上的原始文件重新加载).