线程的内存问题(微小线程,C++)

Memory issue with threads (tinythread, C++)

本文关键字:线程 C++ 内存 问题      更新时间:2023-10-16

我调试了一个奇怪的内存问题:当多线程算法在循环中运行时,它的内存消耗随着每次迭代而增加,尽管GooglePerformanceTools的堆检查器说没有泄漏。最后,我制作了一个单独的最小程序来重现该错误。似乎线程是问题所在:

#include <stdio.h>
#include <iostream>
#include <vector>
#include "tinythread.h"
using namespace std;

int a(0);
void doNothingAtAll(void*)
{
++a;
}
void startAndJoin100()
{   
vector<tthread::thread*> vThreads;
for(int i=0;i<100;++i)
{   
vThreads.push_back(new tthread::thread(doNothingAtAll,NULL));
}
while(!vThreads.empty())
{
tthread::thread* pThread(vThreads.back());
pThread->join();
delete pThread;
vThreads.pop_back();
}
}
int main()
{       
for(int i=0;i<10;++i)
{
cout<<"calling startAndJoin100()"<<endl;
startAndJoin100();
cout<<"all threads joined"<<endl;
cin.get();
}
return 0;
}

main() 调用 10 次 startAndJoin100()。它在每次迭代后等待击键,以便可以获取内存消耗(在 Ubuntu 17.10,64 位下):

VIRT
2.1 GB
4 GB
5.9 GB
7.8 GB
9.6 GB
11.5 GB
13.4 GB
15.3 GB
17.2 GB
19.0 GB

注意:C++11 不能使用,程序必须在 Linux 和 Windows 上编译,因此使用 tinythread。使用生成文件的最小测试代码: geom.at/_downloads/testTinyThread.zip

我回答我自己的问题,这可能对以后的人有用:

结论:

1)我真的很想保留TinyThread,因为C++11不可用(必须支持VS2008和旧的Linux系统),并且不能链接其他库(TinyThread仅由*.h和*.cpp文件组成,而Boost和其他我知道的解决方案需要链接DLL)。

2) Valgrind 和 GooglePerformanceTools 的堆检查器不报告内存泄漏,我已经研究了代码 - 这似乎是正确的,尽管在上面发布的最小示例中虚拟内存消耗急剧增加。似乎系统没有重用以前分配的内存页,我还没有找到这种行为的解释。因此,我不责怪TinyThread++,但是当直接使用pthreads时,它可以工作。

3)解决方法:有一个名为TinyCThread的C替代方案:https://tinycthread.github.io/也适用于C++,并且不会导致TinyThread++观察到的问题。