由在 DTor 之前删除的静态对象创建的线程?
Thread created by static object deleted before DTor?
我的代码中有以下 class。
换句话说,CTor中有一个创建线程的静态对象(单例),当它的DTor被调用时,它在这个线程的上下文中有一些工作要做(DTor为线程放置一些工作)。
我面临的问题是,当调用 B 的 DTor 时,进程中没有其他线程 运行 - 似乎这个线程在调用 [=32 的析构函数之前被进程清理杀死=] B.
有人知道为什么会这样吗?以及如何避免?
UPD:仅当从 DLL 创建 Singleton 时才会出现问题。从同一个可执行文件创建 Singleton 时一切正常。
我正在使用 VS2017
Singleton.dll (A.h + A.cpp)
A.h -->
#pragma once
#include <thread>
class __declspec(dllexport) A
{
public:
static A* instance();
A();
~A();
private:
bool stopFlag;
std::thread mThread;
};
A.cpp
#include "stdafx.h"
#include <thread>
#include "A.h"
using namespace std;
A::A()
{
mThread = std::thread([this] { while (stopFlag == false) { } });
}
A::~A()
{
stopFlag = true;
mThread.join();
}
A* A::instance()
{
static A self;
return &self;
}
=========================================== ===================================
使用 DLL 的可执行文件
main.cpp
#include "stdafx.h"
#include "A.h"
int main()
{
auto a = A::instance();
return 0;
}
更新了可编译代码。现在如果你将前两个文件编译为DLL,然后在A的析构函数中放置断点,你会看到带有lambda函数的线程不存在....
更新:找到 myslef 的答案。在 Windows 中,DLL 中的静态对象在所有线程都已清理的最后一点被卸载
https://msdn.microsoft.com/en-us/library/windows/desktop/dn633971(v=vs.85).aspx
自己找答案。在 Windows 中,来自 DLL 的静态对象在所有线程都已清理的最后一点加载 https://msdn.microsoft.com/en-us/library/windows/desktop/dn633971(v=vs.85).aspx
我的代码中有以下 class。 换句话说,CTor中有一个创建线程的静态对象(单例),当它的DTor被调用时,它在这个线程的上下文中有一些工作要做(DTor为线程放置一些工作)。
我面临的问题是,当调用 B 的 DTor 时,进程中没有其他线程 运行 - 似乎这个线程在调用 [=32 的析构函数之前被进程清理杀死=] B.
有人知道为什么会这样吗?以及如何避免?
UPD:仅当从 DLL 创建 Singleton 时才会出现问题。从同一个可执行文件创建 Singleton 时一切正常。
我正在使用 VS2017
Singleton.dll (A.h + A.cpp)
A.h -->
#pragma once
#include <thread>
class __declspec(dllexport) A
{
public:
static A* instance();
A();
~A();
private:
bool stopFlag;
std::thread mThread;
};
A.cpp
#include "stdafx.h"
#include <thread>
#include "A.h"
using namespace std;
A::A()
{
mThread = std::thread([this] { while (stopFlag == false) { } });
}
A::~A()
{
stopFlag = true;
mThread.join();
}
A* A::instance()
{
static A self;
return &self;
}
=========================================== ===================================
使用 DLL 的可执行文件
main.cpp
#include "stdafx.h"
#include "A.h"
int main()
{
auto a = A::instance();
return 0;
}
更新了可编译代码。现在如果你将前两个文件编译为DLL,然后在A的析构函数中放置断点,你会看到带有lambda函数的线程不存在....
更新:找到 myslef 的答案。在 Windows 中,DLL 中的静态对象在所有线程都已清理的最后一点被卸载 https://msdn.microsoft.com/en-us/library/windows/desktop/dn633971(v=vs.85).aspx
自己找答案。在 Windows 中,来自 DLL 的静态对象在所有线程都已清理的最后一点加载 https://msdn.microsoft.com/en-us/library/windows/desktop/dn633971(v=vs.85).aspx