GNU/Linux >> Linux の 問題 >  >> Linux

new[] は、設定されるまで使用可能なメモリを減少させません

ライブラリが OS からメモリを割り当てる場合、OS はプロセスの仮想アドレス空間にアドレス範囲を予約するだけです。あなたが実証したように、OS が実際にこのメモリを使用するまで提供する理由はありません。

たとえば、 /proc/self/maps アドレス範囲が表示されます。 top のメモリを参照する場合は use 表示されません - まだ使用していません。


オーバーコミットを調べてください。デフォルトでは、Linux はアクセスされるまでメモリーを予約しません。また、使用可能なメモリよりも多くのメモリが必要になった場合、エラーは発生しませんが、ランダムなプロセスが強制終了されます。この動作は /proc/sys/vm/* で制御できます .

IMO、オーバーコミットは、グローバル設定ではなく、プロセスごとの設定にする必要があります。また、デフォルトはノー オーバーコミットです。


質問の後半について:

言語標準では、bad_alloc をスローする際の遅延は許可されていません。これは、ポインターを返す new[] の代わりとして発生する必要があります。後で起こることはありません!

一部の OS は、メモリ割り当てをオーバーコミットしようとし、後で失敗する場合があります。これは C++ 言語標準に準拠していません。


Linux
  1. Linuxのメモリ使用量

  2. Grep:メモリが使い果たされましたか?

  3. SQL Server Standardは、使用可能なすべてのメモリを使用します

  1. PHPのメモリ制限

  2. コピーで使用するキャッシュを制限して、他のキャッシュに使用できるメモリを残すにはどうすればよいですか?

  3. Linuxで大量の仮想メモリを割り当てることは可能ですか?

  1. Ubuntu20.04LTSで利用可能なメモリを確認する4つの方法

  2. Linux –ディストリビューション間で移植可能なメモリの量を取得するにはどうすればよいですか?

  3. ioremap() とは