线程传参、线程ID

传递临时对象作线程参数

#include<ioatream>
#include<thread>
using namespace std;
void nowork(const int& a)
{
    cout<<huyanluanyu<<endl;
}
int main()
{
    int a=677;
    thread newdozer(nowork,a);
    newdozer.detach();
}

向新创建的线程中传递参数并不复杂,仅需在初始化thread对象时传递线程入口的后面加上传递的参数列表。这种参数的传递,实际上是在新线程中复制一份相同的数据,即使参数设置为了引用,但实际上仅是复制了内容,主线程引用对象的销毁并不会对新线程产生影响。这样防止了使用detach操作后主线程比新线程先释放内存对新线程的影响。这也是指针是不可以被传递到新线程的原因。

使用detach还有一种情况,如果传递的实参类型和形参不符,可以的情况下,编译器会进行隐式的类型转换。这种类型转换实际上发生在新线程中。这样会产生一个问题,在这种隐式的类型转换发生之前主线程已经执行完毕释放了实参的内存。为了避免这种情况,需要将实参转换为与形参类型相同临时对象,再用原实参初始化该临时对象。这样传递类型相吻合,就避免了使用释放过的对象。

线程ID

线程ID(Thread ID,简称TID)是操作系统分配给线程的唯一标识符,用于标识和区分不同的线程。线程ID在程序执行和调试过程中起着重要作用,特别是在多线程程序中,可以帮助开发者跟踪和管理线程的执行情况。

在C++中,开发者可以使用操作系统提供的API函数来获取当前线程的ID。线程ID通常是一个整数,用于标识不同的线程。这个ID是由操作系统内核分配的,并且在线程的生命周期内是唯一的,不会被其他线程使用。

线程ID实际上是一个数字。可以使用C++标准库中的std::this_thread_get_id()函数来获取。

传递引用、智能指针作线程参数

如果需要将一个对象作为参数传递给线程函数,并且希望线程函数能够直接修改这个对象时,可以通过std::ref()处理传递对象。由于线程函数通常接受参数的复制版本(除非特别指定为引用),因此直接传递对象会导致线程函数操作的是对象的副本,而不是原始对象。使用 `std::ref()` 可以帮助确保线程函数操作的是原始对象的引用。

传递智能指针智能指针作线程参数时,如果传递的是unique_ptr,那么应该使用移动语义std::move(),移动后,原始的unique_ptr对象将变为空指针,线程函数将拥有该指针的所有权。而shared_ptr可以直接传递。多个线程可以共享对同一动态分配内存的访问权。

注意:传递引用、智能指针作线程参数时,要保证关联内存的生命周期,避免使用detach()。

猜你喜欢

转载自blog.csdn.net/2301_78933228/article/details/138421464