c++ - 使用 malloc 分配比现有内存更多的内存

标签 c++ c linux memory memory-management

此代码片段每次从 stdin 读取字母“u”时都会分配 2Gb,并在读取“a”时初始化所有分配的字符。

#include <iostream>
#include <stdlib.h>
#include <stdio.h>
#include <vector>
#define bytes 2147483648
using namespace std;
int main()
{
    char input [1];
    vector<char *> activate;
    while(input[0] != 'q')
    {
        gets (input);
        if(input[0] == 'u')
        {
            char *m = (char*)malloc(bytes);
            if(m == NULL) cout << "cant allocate mem" << endl;
            else cout << "ok" << endl;
            activate.push_back(m);
        }
        else if(input[0] == 'a')
        {
            for(int x = 0; x < activate.size(); x++)
            {
                char *m;
                m = activate[x];
                for(unsigned x = 0; x < bytes; x++)
                {
                    m[x] = 'a';
                }
            }
        }
    }
    return 0;
}

我在具有 3Gb RAM 的 Linux 虚拟机上运行此代码。在使用htop工具监控系统资源使用情况时,我发现malloc操作没有反射(reflect)在资源上。

例如,当我仅输入“u”一次(即分配2GB堆内存)时,我没有看到htop中的内存使用量增加了2GB。只有当我输入“a”(即初始化)时,我才会看到内存使用量增加。

因此,我能够“分配”比现有更多的堆内存。例如,我可以 malloc 6GB(这超过了我的 ram 和交换内存)并且 malloc 允许它(即 malloc 不返回 NULL)。但是当我尝试初始化分配的内存时,我可以看到内存和交换内存已填满,直到进程被终止。

-我的问题:

1.这是内核错误吗?

2.有人可以向我解释一下为什么允许这种行为吗?

最佳答案

它的名字是memory overcommit 。您可以通过以 root 身份运行来禁用它:

 echo 2 > /proc/sys/vm/overcommit_memory

这不是我喜欢的内核功能(所以我总是禁用它)。请参阅malloc(3)mmap(2)proc(5)

注意:echo 0 代替 echo 2 经常 - 但并非总是 - 也可以。阅读文档(特别是我刚刚链接到的 proc 手册页)。

关于c++ - 使用 malloc 分配比现有内存更多的内存,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39686663/

相关文章:

c - 在 C 中使用 fgets 进行乘法运算

linux - 如何在Linux中每个应用程序的开始和结束时执行脚本?

c++ - 添加公共(public)变量时崩溃

c++ - C/C++错误:超出范围读取。寻找错误的内存地址

c - 在端口 53 上的 C 中获取 DNS 查询。要绑定(bind)到的地址是什么?

c - 如何使用 C 在 Linux 中从串口读取数据?

python - 构建 docker 镜像时出现错误消息 "Error processing tar file(exit status 1)"

c++ - 堆栈中的内存错误

c++ - 汇编中的内联 C++ 方法

c++ - 如何找到指针使用的字节数?