【发布时间】:2010-12-02 15:15:45
【问题描述】:
以下测试用例在使用 OpenMP 时在“post MT section”消息之后的循环中在 32 位机器上耗尽内存(抛出 std::bad_alloc),但是,如果 OpenMP 的#pragmas 被注释掉,代码运行正常,所以看起来当内存在并行线程中分配时,它没有正确释放,因此我们用完了内存。
问题是下面的内存分配和删除代码是否有问题,或者这是 gcc v4.2.2 或 OpenMP 中的错误?我也尝试了 gcc v4.3 并得到了同样的失败。
int main(int argc, char** argv)
{
std::cout << "start " << std::endl;
{
std::vector<std::vector<int*> > nts(100);
#pragma omp parallel
{
#pragma omp for
for(int begin = 0; begin < int(nts.size()); ++begin) {
for(int i = 0; i < 1000000; ++i) {
nts[begin].push_back(new int(5));
}
}
}
std::cout << " pre delete " << std::endl;
for(int begin = 0; begin < int(nts.size()); ++begin) {
for(int j = 0; j < nts[begin].size(); ++j) {
delete nts[begin][j];
}
}
}
std::cout << "post MT section" << std::endl;
{
std::vector<std::vector<int*> > nts(100);
int begin, i;
try {
for(begin = 0; begin < int(nts.size()); ++begin) {
for(i = 0; i < 2000000; ++i) {
nts[begin].push_back(new int(5));
}
}
} catch (std::bad_alloc &e) {
std::cout << e.what() << std::endl;
std::cout << "begin: " << begin << " i: " << i << std::endl;
throw;
}
std::cout << "pre delete 1" << std::endl;
for(int begin = 0; begin < int(nts.size()); ++begin) {
for(int j = 0; j < nts[begin].size(); ++j) {
delete nts[begin][j];
}
}
}
std::cout << "end of prog" << std::endl;
char c;
std::cin >> c;
return 0;
}
【问题讨论】:
-
当我在使用英特尔编译器构建的 Windows 下运行它时,由于达到 32 位进程的 2gb 限制,我的分配在第一个循环中开始失败。 OpenMP 的开销是否可能只是将您的进程推到了平台上的任何限制之上?
-
@Scott Danahy 尝试更改测试用例以将所有分配减半,此测试使用 4 GB 限制。
标签: multithreading gcc memory-leaks openmp allocator