c++ - 为什么调用大尺寸的 mmap() 不会失败?

标签 c++ c linux memory-management mmap

我尝试使用 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_NONEmmap,并删除对 mprotect 的调用。

如果您需要将内存直接驻留在 RAM 中,请为此使用 mlock。如果没有足够的 RAM 可用,它将失败。在许多 linux 平台(包括 Ubuntu)上,有一个资源限制(RLIMIT_MEMLOCK)限制任何进程可以锁定多少内存;您可以使用 ulimit -l 进行调整。

关于c++ - 为什么调用大尺寸的 mmap() 不会失败?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9129004/

相关文章:

c++ - 如何使用 OpenCV 或其他库从图像中检测电视屏幕?

android - proc/[pid]/stat 中的值是什么意思?

c++ - 类似文件夹树浏览器的 Windows 资源管理器

c++ - 第一次计算后的错误值

c# - 在 Windows 上将数据插入文件

c - 在启动 linux 时以编程方式启动应用程序

c - 纯C代码示例中的utf8到char编码

c - 如何在 Python C API 中获取返回的 PyObject 的指针?

linux - SSH 远程命令退出代码

linux - 如何在 Linux Enthought Canopy 中启动 Spyder