我尝试使用 mmap()
来操作虚拟内存。我想保留并提交一个内存区域。我测试了这段代码:
const unsigned long gygabyte = 1024 * 1024 * 1024;
const unsigned long gygabyteCount = 2;
const unsigned long maxCapacity = gygabyteCount * gygabyte;
int main()
{
char* pMemory;
pMemory = (char*)mmap(NULL, maxCapacity, PROT_NONE, MAP_PRIVATE | MAP_ANONYMOUS, -1, 0);
if ( mprotect(pMemory, maxCapacity, PROT_READ | PROT_WRITE) != 0 )
{
cout << "Memory Allocation has failed" << endl;
}
usleep(-1);
return 0;
}
我从一个终端运行了我的程序的几个拷贝(比如 6 个)。我从来没有在任何一个中看到“内存分配失败”。我在 64 位 Ubuntu 和 4GB RAM 上运行。谁能告诉我一些关于这方面的事情吗?
最佳答案
mmap
保留进程的虚拟地址空间区域,但不会立即为其分配物理 RAM。因此,在 64 位平台上,您可以保留大量而不会失败(尽管您仍然需要检查失败;您的示例代码不需要)。访问内存时,稍后会分配 RAM 的物理页面。
mprotect
只是改变保留内存的读/写访问;它也不会使它驻留在 RAM 中。通过传递 PROT_READ | 你会得到同样的效果PROT_WRITE
而不是 PROT_NONE
到 mmap
,并删除对 mprotect
的调用。
如果您需要将内存直接驻留在 RAM 中,请为此使用 mlock
。如果没有足够的 RAM 可用,它将失败。在许多 linux 平台(包括 Ubuntu)上,有一个资源限制(RLIMIT_MEMLOCK
)限制任何进程可以锁定多少内存;您可以使用 ulimit -l
进行调整。
关于c++ - 为什么调用大尺寸的 mmap() 不会失败?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9129004/