时间:2021-05-20
多线程中使用lambda
在本篇文章中,主要介绍lambda函数在多线程中的使用。
先从下面的例子开始吧:
#include <iostream>#include <thread>int main(){ std::thread t([]() { std::cout << "thread function\n"; }); std::cout << "main thread\n"; t.join(); return 0;}在此基础上我们将创建5个线程,然后把线程放进一个vector容器中, 用for_each()完成线程的汇合(join):
#include <iostream>#include <thread>#include <vector>#include <algorithm>int main(){ // vector 容器存储线程 std::vector<std::thread> workers; for (int i = 0; i < 5; i++) { workers.push_back(std::thread([]() { std::cout << "thread function\n"; })); } std::cout << "main thread\n"; // 通过 for_each 循环每一个线程 // 第三个参数赋值一个task任务 // 符号'[]'会告诉编译器我们正在用一个匿名函数 // lambda函数将它的参数作为线程的引用t // 然后一个一个的join std::for_each(workers.begin(), workers.end(), [](std::thread &t;) { t.join(); }); return 0;}输出应该像这样:
thread function
thread function
thread function
thread function
thread function
main thread
vector容器包含个工作线程,然后在它们结束任务之后,与主线程汇合。
并发编程的不确定性
从上面的输出中可以看出,我们无法分辨哪一个线程在打印。
因此,我们需要在每个线程上添加一个标记。鉴于我们使用lambda,所以我们可以尝试下它的捕获能力。
通过将i的值传递给线程,使用[i]我们可以将索引传递到线程函数中:
for (int i = 0; i < 5; i++) { workers.push_back(std::thread([i]() { std::cout << "thread function " << i << "\n"; }));}输出:
thread function thread function thread function thread function thread function
main thread
4
2
1
0
3
每次运行的输出可能不同,这体现了并发编程的不确定性性质。
此外,我们可以从输出中看到,甚至在打印语句之间,也可以是抢占式的,换句话说,调度程序可以随时中断。
因此,由于当前编程的性质,我们使用lambda捕获特性的努力没有成功。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
在C++11和C#中都有匿名函数的存在。下面看看在python中匿名函数的使用。1.lambda只是一个表达式,函数体比def简单很多。2.lambda的主体是
1,简介C++11中加入了头文件,此头文件主要声明了std::thread线程类。C++11的标准类std::thread对线程进行了封装,定义了C++11标准
c++11之后有了标准的线程库:std::thread。之前一些编译器使用C++11的编译参数是-std=c++11g++-std=c++11test.cpps
方法一:结合lambda表达式、函数调用运算符、标准库函数对象、C++11标准新增的标准库function类型,编写一个简单的计算器,可实现简单的加、减、乘、除
lambda简介熟悉Python的程序员应该对lambda不陌生。简单来说,lambda就是一个匿名的可调用代码块。在C++11新标准中,lambda具有如下格