c++ 线程
创始人
2024-12-08 08:09:37
0

在 C++ 中,std::thread 构造函数可以用于将参数传递给线程。这里是一个基本的示例,展示了如何使用 std::thread 来传递参数:

#include  #include   // 定义一个被线程调用的函数 void threadFunc(int arg1, double arg2, std::string arg3) {     std::cout << "arg1: " << arg1 << ", arg2: " << arg2 << ", arg3: " << arg3 << std::endl; }  int main() {     // 创建一个线程,并传递参数     std::thread t(threadFunc, 1, 3.14, "Hello, World!");      // 等待线程结束     t.join();      return 0; } 

在这个例子中,定义了一个函数 threadFunc,它接受三个参数。然后在 main 函数中创建了一个线程,并将这三个参数传递给了 threadFunc

如果函数参数是引用类型,可以使用 std::refstd::cref 来传递引用:

#include  #include  #include  // std::ref 和 std::cref 需要这个头文件  // 定义一个被线程调用的函数 void threadFunc(int &arg1, double &arg2, std::string &arg3) {     std::cout << "arg1: " << arg1 << ", arg2: " << arg2 << ", arg3: " << arg3 << std::endl; }  int main() {     int arg1 = 1;     double arg2 = 3.14;     std::string arg3 = "Hello, World!";      // 创建一个线程,并传递参数引用     std::thread t(threadFunc, std::ref(arg1), std::ref(arg2), std::ref(arg3));      // 等待线程结束     t.join();      return 0; } 

在这个例子中,使用 std::ref 来传递变量的引用,这样就可以在 threadFunc 中修改这些变量的值。

std::refstd::cref 是 C++11 引入的,用于在函数绑定或异步函数调用中引用成员函数或者非成员函数。这些函数主要在多线程中使用,目的是在函数调用中保持对象的引用,而不是复制对象。

std::refstd::cref 的使用

  1. std::ref:
    std::ref 用于在函数绑定或异步函数调用中引用非 const 对象。例如:

    std::thread t(func, std::ref(myObj)); 
  2. std::cref:
    std::cref 类似于 std::ref,但它用于引用 const 对象。例如:

    std::thread t(func, std::cref(myObj)); 

这两个函数都定义在 头文件中,因此在使用它们之前,必须包含这个头文件。

多线程示例

以下是一个示例,展示了如何使用 std::threadstd::promise 进行线程同步:

#include  #include  #include  #include   int main() {     std::promise promise;     std::future future = promise.get_future();      std::thread t([&promise] {         std::string s = "hello";         std::this_thread::sleep_for(std::chrono::seconds(1));         promise.set_value(s);     });      t.join();     std::string value = future.get();     std::cout << value << std::endl;      return 0; } 

使用信号量的多线程示例

下面是一个使用信号量和互斥锁进行线程同步的示例:

#include  #include  #include  #include  #include   std::mutex mtx; sem_t sem; int counter = 0;  void increment_counter(int id) {     sem_wait(&sem);     std::lock_guard lock(mtx);     std::this_thread::sleep_for(std::chrono::milliseconds(100));     counter++;     std::cout << "Thread " << id << " incremented counter to " << counter << std::endl;     sem_post(&sem); }  void read_counter(int id) {     sem_wait(&sem);     std::lock_guard lock(mtx);     std::this_thread::sleep_for(std::chrono::milliseconds(100));     std::cout << "Thread " << id << " read counter value " << counter << std::endl;     sem_post(&sem); }  int main() {     sem_init(&sem, 0, 5);      std::vector threads;     for (int i = 0; i < 10; ++i) {         if (i % 2 == 0) {             threads.push_back(std::thread(increment_counter, i));         } else {             threads.push_back(std::thread(read_counter, i));         }     }      for (auto &thread : threads) {         thread.join();     }      sem_destroy(&sem);      return 0; } 

在这个示例中,使用了信号量和互斥锁来控制对共享资源 counter 的访问。这样可以确保多个线程安全地访问和修改共享资源。

相关内容

热门资讯

脚本辅助挂(wepoke)外挂... 脚本辅助挂(wepoke)外挂软件透明APP(智能ai代打)其实真的有挂(2023已更新)(今日头条...
透明辅助挂!wepoke插件&... 透明辅助挂!wepoke插件"wpk免费赛规则"一直真的有挂(有挂漏洞)-微博热搜;1、全新机制【w...
黑科技辅助挂(红龙扑克)wpk... 黑科技辅助挂(红龙扑克)wpk俱乐部系统(透视挂)的确是有挂的(有挂ai辅助)-头条红龙扑克软件透明...
黑科技辅助(好运大菠萝)外挂辅... 黑科技辅助(好运大菠萝)外挂辅助挂(辅助挂)就是真的有挂(2025已更新)(哔哩哔哩)1、实时好运大...
黑科技辅助!wpk有辅助挂&q... 黑科技辅助!wpk有辅助挂"cloudpoker辅助器"果真真的有挂(有挂测试)-今日头条1、每一步...
透明辅助挂(x-poker)德... 透明辅助挂(x-poker)德州wpk辅助(软件透明挂)果真真的有挂(有挂技巧)-知乎;一、德州wp...
德州辅助(WePoke)外挂软... 德州辅助(WePoke)外挂软件透明安装(透视)原来真的有挂(2021已更新)(小红书)1、打开软件...
透明辅助挂!wpk真的有外挂&... 透明辅助挂!wpk真的有外挂"德州ai人工智能"一直真的有挂(有挂安卓版本)-头条;1、德州ai人工...
黑科技辅助挂(gg扑克)wep... 黑科技辅助挂(gg扑克)wepoke怎么来好牌(辅助挂)的确是有挂的(有挂安装)-今日头条;gg扑克...
黑科技辅助挂(来玩德州扑克约局... 黑科技辅助挂(来玩德州扑克约局)外挂软件透明器(辅助挂)原来真的有挂(2023已更新)(知乎);1)...