このコード スニペットは、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 操作がリソースに反映されていないことに気付きました。
たとえば、'u' を 1 回だけ入力した場合 (つまり、2GB のヒープ メモリを割り当てた場合)、htop でメモリ使用量が 2GB 増加することはありません。'a' を入力したとき (つまり、初期化) にのみ、メモリ使用量が増加しています。
その結果、存在するよりも多くのヒープ メモリを "malloc" することができます。たとえば、6GB (RAM とスワップ メモリよりも大きい) を malloc でき、malloc はそれを許可します (つまり、malloc は NULL を返しません)。しかし、割り当てられたメモリを初期化しようとすると、プロセスが強制終了されるまでメモリとスワップ メモリがいっぱいになるのがわかります。
-私の質問:
1.これはカーネルのバグですか?
2.この振る舞いが許可されている理由を誰か説明してもらえますか?