システム (x86、x64、PowerPC / Windows、Linux、または MacOS) で、標準のC++11 でクラッシュせずに残りの利用可能なメモリを取得することは可能ですか?
単純な方法は、大きすぎるサイズから始めて非常に大きな配列を割り当て、失敗するたびに例外をキャッチし、例外がスローされなくなるまでサイズを小さくすることです。しかし、もっと効率的で賢い方法があるかもしれません...
EDIT 1:実際には、正確な量のメモリは必要ありません。コードを起動したときにコードが使用できる量をおおよそ (100MB のエラー バー) 知りたいです。
EDIT 2: このコードについてどう思いますか? プログラムの開始時に実行しても安全ですか、それともメモリが破損する可能性がありますか?
#include <iostream>
#include <array>
#include <list>
#include <initializer_list>
#include <stdexcept>
int main(int argc, char* argv[])
{
static const long long int megabyte = 1024*1024;
std::array<char, megabyte> content({{'a'}});
std::list<decltype(content)> list1;
std::list<decltype(content)> list2;
const long long int n1 = list1.max_size();
const long long int n2 = list2.max_size();
long long int i1 = 0;
long long int i2 = 0;
long long int result = 0;
for (i1 = 0; i1 < n1; ++i1) {
try {
list1.push_back(content);
}
catch (const std::exception&) {
break;
}
}
for (i2 = 0; i2 < n2; ++i2) {
try {
list2.push_back(content);
}
catch (const std::exception&) {
break;
}
}
list1.clear();
list2.clear();
result = (i1+i2)*sizeof(content);
std::cout<<"Memory available for program execution = "<<result/megabyte<<" MB"<<std::endl;
return 0;
}