原因:c11里面的thread用法,故在此进行梳理一下
概况:通过类内调用与跨类进行调用进行代码分析。
首先分析一下thread头文件:
explicit thread(_Fn&& _Fx, _Args&&... _Ax)
thread(thread&& _Other) _NOEXCEPT
bool joinable() //判断线程声明周期是否有效
void join(); //阻塞直到线程退出
void detach();//托管线程
native_handle_type native_handle()//获取线程句柄
1:普通调用流程如下
void Function(int i)
{
......
}
{
std::thread t(Function,1);
t.detach();//t.join();
}
2:类内部不同方法进行线程创建,此时线程的创建需要指定成员函数地址,和当前成员对象。通过native_handle方法获取线程句柄,通过joinable方法来判断线程的声明周期。
class CTest {
public:
void t1_thread(int i)
{
for (int i= 0;i<1000;i++)
{
printf("t1_thread.\n");
}
}
void CTestThread1()
{
m_t = std::thread(&CTest::t1_thread,this,1);
}
void GetThread()
{
bool bre = m_t.joinable();//判断当前线程是否有效
void