ライブラリが OS からメモリを割り当てる場合、OS はプロセスの仮想アドレス空間にアドレス範囲を予約するだけです。あなたが実証したように、OS が実際にこのメモリを使用するまで提供する理由はありません。
たとえば、 /proc/self/maps
アドレス範囲が表示されます。 top のメモリを参照する場合は use 表示されません - まだ使用していません。
オーバーコミットを調べてください。デフォルトでは、Linux はアクセスされるまでメモリーを予約しません。また、使用可能なメモリよりも多くのメモリが必要になった場合、エラーは発生しませんが、ランダムなプロセスが強制終了されます。この動作は /proc/sys/vm/*
で制御できます .
IMO、オーバーコミットは、グローバル設定ではなく、プロセスごとの設定にする必要があります。また、デフォルトはノー オーバーコミットです。
質問の後半について:
言語標準では、bad_alloc をスローする際の遅延は許可されていません。これは、ポインターを返す new[] の代わりとして発生する必要があります。後で起こることはありません!
一部の OS は、メモリ割り当てをオーバーコミットしようとし、後で失敗する場合があります。これは C++ 言語標準に準拠していません。