创建线程时传递参数给线程
在C++中,可以使用 std::thread 来创建和管理线程,同时可以通过几种方式将参数传递给线程函数。这些方法包括使用值传递、引用传递和指针传递。下面将对这些方法进行详细讲解并给出相应的代码示例。
1. 值传递参数
当你创建线程并希望传递参数时,可以直接将参数作为 std::thread 构造函数的参数传递。这会将参数的副本传递给线程。
示例代码:使用值传递参数
#include <iostream>
#include <thread>void thread_function(int value) {std::cout << "Thread received value: " << value << std::endl;
}int main() {int value_to_pass = 10;std::thread t(thread_function, value_to_pass); // 传递参数t.join(); // 等待线程完成return 0;
}
2. 引用传递参数
如果希望传递参数的引用,以避免复制开销,可以使用 std::ref() 来包装参数。这对于大型对象特别有用。
示例代码:使用引用传递参数
#include <iostream>
#include <thread>
#include <vector>
#include <functional> // 为 std::ref 使用void thread_function(std::vector<int>& vec) {vec.push_back(5); // 修改传入的向量std::cout << "Thread modified vector to include 5." << std::endl;
}int main() {std::vector<int> vec;std::thread t(thread_function, std::ref(vec)); // 传递引用t.join(); // 等待线程完成std::cout << "Vector size after thread: " << vec.size() << std::endl; // 输出:1return 0;
}
3. 传递结构体或类对象
可以通过传递结构体或类对象的方式将多个参数传递给线程。这个过程与使用值传递或引用传递相结合,可以根据需要进行操作。
示例代码:传递结构体作为参数
#include <iostream>
#include <thread>struct ThreadData {int id;std::string message;
};void thread_function(ThreadData data) {std::cout << "Thread " << data.id << ": " << data.message << std::endl;
}int main() {ThreadData data = {1, "Hello from thread!"};std::thread t(thread_function, data); // 传递结构体t.join(); // 等待线程完成return 0;
}
4. 线程接受多个参数
通过将多个参数传递给线程,可以直接在创建 std::thread 时指定多个参数。
示例代码:传递多个参数
#include <iostream>
#include <thread>void thread_function(int a, double b) {std::cout << "Thread received integer: " << a << " and double: " << b << std::endl;
}int main() {std::thread t(thread_function, 42, 3.14); // 传递多个参数t.join(); // 等待线程完成return 0;
}
总结
通过以上示例,我们展示了在C++中创建线程及传递参数的不同方式:
- 值传递:直接传递参数的副本。
- 引用传递:使用 std::ref() 传递对象的引用,避免复制。
- 结构体或类对象:将多个参数封装到一个结构体中进行传递。
- 多个参数传递:在创建线程时可以直接传递多个参数。
这种灵活性使得在多线程编程中能够更好地管理数据和资源。根据具体的应用场景,可以选择合适的参数传递方式。
在C++中,除了使用常规的函数作为线程的入口点外,我们还可以使用 lambda 表达式 和 类的成员函数。这两种方式可以使代码更加灵活和简洁。下面将提供示例代码,展示如何使用这两种形式创建线程并传递参数。
1. 使用 Lambda 表达式
Lambda 表达式可以直接在创建线程时定义,非常适合进行简短的任务。在 lambda 中,可以捕获外部变量并将其用于线程中。
示例代码:使用 Lambda 表达式
#include <iostream>
#include <thread>int main() {int value = 42;// 创建线程时使用 lambda 表达式std::thread t([value]() {std::cout << "Thread is running, received value: " << value << std::endl;});t.join(); // 等待线程完成return 0;
}
2. 使用 类的成员函数
如果你有一个对象,并希望使用该对象的成员函数作为线程的入口,可以使用 std::thread 的构造函数将对象的成员函数与对象本身一同传递。必须确保对象在调用之前保持有效。
示例代码:使用类的成员函数
#include <iostream>
#include <thread>class MyClass {
public:void member_function(int value) {std::cout << "Thread running from member function, received value: " << value << std::endl;}
};int main() {MyClass obj;int value = 100;// 创建线程并传递成员函数和对象std::thread t(&MyClass::member_function, &obj, value);t.join(); // 等待线程完成return 0;
}
3. Lambda 表达式与复杂参数
Lambda 表达式还可以接受多个参数,并且可以捕获外部变量,例如引用或指针。下面的示例展示了如何捕获引用。
示例代码:Lambda 表达式捕获引用
#include <iostream>
#include <thread>
#include <vector>int main() {std::vector<int> vec = {1, 2, 3};// 使用 lambda 表达式修改 vectorstd::thread t([&vec]() {vec.push_back(4);std::cout << "Thread modified vector." << std::endl;});t.join(); // 等待线程完成std::cout << "Vector size after thread: " << vec.size() << std::endl; // 输出:4return 0;
}
4. 成员函数与多个参数
可以通过类的成员函数传递多个参数。在实例化 std::thread 时,将这些参数传递给成员函数。
示例代码:成员函数与多个参数
#include <iostream>
#include <thread>class MyClass {
public:void member_function(int a, double b) {std::cout << "Thread from member function, received int: " << a<< " and double: " << b << std::endl;}
};int main() {MyClass obj;// 创建线程并传递成员函数及参数std::thread t(&MyClass::member_function, &obj, 42, 3.14);t.join(); // 等待线程完成return 0;
}
总结
通过以上示例,我们展示了如何使用 lambda 表达式 和 类的成员函数 在C++中创建线程并传递参数。
- Lambda 表达式:能够快速定义匿名函数,并且能够捕获外部变量。适合简单的任务。
- 类的成员函数:能在对象的上下文中执行功能,可以通过传递对象的指针来调用它们。适用于需要利用对象状态的情况。
这些方式可以使得多线程编程更灵活、更易读,开发者可以根据具体需求选择合适的方式。
相关文章:

创建线程时传递参数给线程
在C中,可以使用 std::thread 来创建和管理线程,同时可以通过几种方式将参数传递给线程函数。这些方法包括使用值传递、引用传递和指针传递。下面将对这些方法进行详细讲解并给出相应的代码示例。 1. 值传递参数 当你创建线程并希望传递参数时ÿ…...

兴业严选|美国总统都是不良资产出身 法拍市场是否将大众化
北京时间11月6日,特朗普赢得美国大选。 说起特朗普那就不得不提他的发家史,那可真是一笔笔不良资产投资堆出来的。 没错,特朗普就是处理不良资产的高手,战果丰硕。 改造斯威夫特小镇、 康莫德酒店、打造特朗普(TRUM…...
C#-拓展方法
概念:为现有的非静态变量类型,添加方法 语法: 访问修饰符 static 返回值 函数名(this 拓展类名 参数名, 参数类型 参数名,参数类型 参数名....){} 而public static void F(this Console()){ }是错的。Console是静态类不可以为静态类添加方…...

加锁失效,非锁之过,加之错也|京东零售供应链库存研发实践
本文导读 从事京东零售供应链库存业务,库存数量操作增减十分频繁,并且项目开发中会常常遇到各种并发情况,一旦库存数量操作有误,势必给前台销售产生损失影响,因此需要关注对库存数量并发操作下的一致性问题。 大部分…...
vue3 传值的几种方式
一.父组件传子组件 父组件 //父组件 <Decisionobject :Decisionselected"Decisionselected"></Decisionobject> <script lang"ts" setup> let Decisionselected ref(false); </script>子组件 <script lang"ts" s…...

AUTOSAR CP NVRAM Manager规范导读
一、NVRAM Manager功能概述 NVRAM Manager是AUTOSAR(AUTomotive Open System ARchitecture)框架中的一个模块,负责管理非易失性随机访问存储器(NVRAM)。它提供了一组服务和API,用于在汽车环境中存储、维护和恢复NV数据。以下是NVRAM Manager的一些关键功能: 数据存储和…...

2024阿里云CTF Web writeup
《Java代码审计》http://mp.weixin.qq.com/s?__bizMzkwNjY1Mzc0Nw&mid2247484219&idx1&sn73564e316a4c9794019f15dd6b3ba9f6&chksmc0e47a67f793f371e9f6a4fbc06e7929cb1480b7320fae34c32563307df3a28aca49d1a4addd&scene21#wechat_redirect 前言 又是周末…...

软件著作权申请教程(超详细)(2024新版)软著申请
目录 一、注册账号与实名登记 二、材料准备 三、申请步骤 1.办理身份 2.软件申请信息 3.软件开发信息 4.软件功能与特点 5.填报完成 一、注册账号与实名登记 首先我们需要在官网里面注册一个账号,并且完成实名认证,一般是注册【个人】的身份。中…...

三维测量与建模笔记 - 3.2 直接线性变换法标定DLT
DLT - Direct Linear Transform 上图中,透视成像对应的公式是共线方程,可以参考以下链接: https://zhuanlan.zhihu.com/p/101549821https://zhuanlan.zhihu.com/p/101549821 对于标定来说,需要找到。已知量是。 (u,v)是…...

Whisper AI视频(音频)转文本
在信息化时代,如何高效处理丰富的音频和视频内容成为了一个重要课题。将这些内容转化为文本不仅能提高信息的可获取性,还能促进更广泛的传播。Whisper Desktop作为一款先进的语音识别工具,能够帮助用户轻松实现音频和视频的转文本功能。 什么…...

全网最详细RabbitMQ教学包括如何安装环境【RabbitMQ】RabbitMQ + Spring Boot集成零基础入门(基础篇)
目录 一、初始Rabbitmq1、什么是Rabbitmq,它的概述是什么?2、RabbitMQ的应用场景3、RabbitMQ主要组件4、RabbitMQ 的优点5、与其他消息队列性能比较 二、RabbitMQ环境安装初始化三、SpringAMQPRabbitMQ实战入门(基本API)1、实战入…...
esp32记录一次错误
报错信息 PS C:\XingNian\GeRen\4Gdownload\wireless-esp8266-dap> idf.py build Executing action: all (aliases: build) Running cmake in directory c:\xingnian\geren\4gdownload\wireless-esp8266-dap\build Executing "cmake -G Ninja -DPYTHON_DEPS_CHECKED1 …...

Moonshine - 新型开源ASR(语音识别)模型,体积小,速度快,比OpenAI Whisper快五倍 本地一键整合包下载
Moonshine 是由 Useful Sensors 公司推出的一系列「语音到文本(speech-to-text, STT)转换模型」,旨在为资源受限设备提供快速而准确的「自动语音识别(ASR)服务」。Moonshine 的设计特别适合于需要即时响应的应用场景&a…...
java-web-苍穹外卖-day1:软件开发步骤简化版+后端环境搭建
软件开发 感觉书本上和线上课程, 讲的太抽象, 不好理解, 但软件开发不就是为了开发应用程序吗?! 干嘛搞这么抽象,对吧, 下面个人对于软件开发的看法, 主打简单易懂, 当然,我一IT界小菜鸟, 对软件开发的认识也很浅显, 这个思维导图也仅仅是现阶段我的看法, 我以后会尽力…...

一个国产 API 开源项目,在 ProductHunt 杀疯了...
随着AI 大模型技术的兴起,全球产品更新和面市进程速度肉眼可见的加快,Product Hunt 作为全球知名的产品发现平台,每日都会精选出一系列产品能力强劲的新产品,这些产品不仅代表了技术前沿,还反映了市场的发展趋势。 上…...

斗破QT编程入门系列之二:认识Qt:编写一个HelloWorld程序(四星斗师)
斗破Qt目录: 斗破Qt编程入门系列之前言:认识Qt:Qt的获取与安装(四星斗师) 斗破QT编程入门系列之一:认识Qt:初步使用(四星斗师) 斗破QT编程入门系列之二:认识…...

木马病毒相关知识
1、 木马的定义 相当于一个远控程序(一个控制端[hack]、一个被控端[受害端]) 在计算机系统中,“特洛伊木马”指系统中被植入的、人为设计的程序,目的包括通过网终远程控制其他用户的计算机系统,窃取信息资料࿰…...

用 Python 写了一个天天酷跑(附源码)
Hello,大家好,给大家说一下,我要开始装逼了 这期写个天天酷跑玩一下叭! 制作一个完整的“天天酷跑”游戏涉及很多方面,包括图形渲染、物理引擎、用户输入处理、游戏逻辑等。由于Python是一种高级编程语言,…...

【网络-交换机】生成树协议、环路检测
路由优先级 路由优先级决定了在多种可达的路由类型中,哪种路由将被用来转发数据包。路由优先级值越低,对应路由的优先级越高,优先级值255表示对应的路由不可达。一般情况下,静态路由的优先级为1,OSPF路由优先级为110&a…...
C++ 中的 JSON 序列化和反序列化:结构体与枚举类型的处理
在 C 编程中,处理 JSON 数据是一项常见任务,特别是在需要与其他系统或前端进行数据交换时。nlohmann::json 库是一个功能强大且易于使用的 JSON 库,它允许我们轻松地在 C 中进行 JSON 数据的序列化和反序列化。本文将详细介绍如何使用 nlohma…...
OpenLayers 可视化之热力图
注:当前使用的是 ol 5.3.0 版本,天地图使用的key请到天地图官网申请,并替换为自己的key 热力图(Heatmap)又叫热点图,是一种通过特殊高亮显示事物密度分布、变化趋势的数据可视化技术。采用颜色的深浅来显示…...
脑机新手指南(八):OpenBCI_GUI:从环境搭建到数据可视化(下)
一、数据处理与分析实战 (一)实时滤波与参数调整 基础滤波操作 60Hz 工频滤波:勾选界面右侧 “60Hz” 复选框,可有效抑制电网干扰(适用于北美地区,欧洲用户可调整为 50Hz)。 平滑处理&…...

【入坑系列】TiDB 强制索引在不同库下不生效问题
文章目录 背景SQL 优化情况线上SQL运行情况分析怀疑1:执行计划绑定问题?尝试:SHOW WARNINGS 查看警告探索 TiDB 的 USE_INDEX 写法Hint 不生效问题排查解决参考背景 项目中使用 TiDB 数据库,并对 SQL 进行优化了,添加了强制索引。 UAT 环境已经生效,但 PROD 环境强制索…...

如何在看板中体现优先级变化
在看板中有效体现优先级变化的关键措施包括:采用颜色或标签标识优先级、设置任务排序规则、使用独立的优先级列或泳道、结合自动化规则同步优先级变化、建立定期的优先级审查流程。其中,设置任务排序规则尤其重要,因为它让看板视觉上直观地体…...
线程与协程
1. 线程与协程 1.1. “函数调用级别”的切换、上下文切换 1. 函数调用级别的切换 “函数调用级别的切换”是指:像函数调用/返回一样轻量地完成任务切换。 举例说明: 当你在程序中写一个函数调用: funcA() 然后 funcA 执行完后返回&…...

Cilium动手实验室: 精通之旅---20.Isovalent Enterprise for Cilium: Zero Trust Visibility
Cilium动手实验室: 精通之旅---20.Isovalent Enterprise for Cilium: Zero Trust Visibility 1. 实验室环境1.1 实验室环境1.2 小测试 2. The Endor System2.1 部署应用2.2 检查现有策略 3. Cilium 策略实体3.1 创建 allow-all 网络策略3.2 在 Hubble CLI 中验证网络策略源3.3 …...

华为OD机试-食堂供餐-二分法
import java.util.Arrays; import java.util.Scanner;public class DemoTest3 {public static void main(String[] args) {Scanner in new Scanner(System.in);// 注意 hasNext 和 hasNextLine 的区别while (in.hasNextLine()) { // 注意 while 处理多个 caseint a in.nextIn…...
MySQL中【正则表达式】用法
MySQL 中正则表达式通过 REGEXP 或 RLIKE 操作符实现(两者等价),用于在 WHERE 子句中进行复杂的字符串模式匹配。以下是核心用法和示例: 一、基础语法 SELECT column_name FROM table_name WHERE column_name REGEXP pattern; …...

成都鼎讯硬核科技!雷达目标与干扰模拟器,以卓越性能制胜电磁频谱战
在现代战争中,电磁频谱已成为继陆、海、空、天之后的 “第五维战场”,雷达作为电磁频谱领域的关键装备,其干扰与抗干扰能力的较量,直接影响着战争的胜负走向。由成都鼎讯科技匠心打造的雷达目标与干扰模拟器,凭借数字射…...

(转)什么是DockerCompose?它有什么作用?
一、什么是DockerCompose? DockerCompose可以基于Compose文件帮我们快速的部署分布式应用,而无需手动一个个创建和运行容器。 Compose文件是一个文本文件,通过指令定义集群中的每个容器如何运行。 DockerCompose就是把DockerFile转换成指令去运行。 …...