首页
学习
活动
专区
圈层
工具
发布

C++并发低级接口:std::thread和std::promise

创建新线程异步输出"A",然后主线程输出"B",td.join()就是所谓的创建它的线程还必须指定以何种策略等待新线程,有两种策略可供选择: std::thread.join() 阻塞直到子线程结束 std...虽然std::thread.detach()可以不阻塞主线程,但是如果主线程结束那这些后台任务都会强行终止,比如你后台是下载任务,所以几乎没有直接用detach的,都是配合后面的同步机制如std::condition_variable...这里也凸显了std::async的高级和std::thread的低级:在std::async中我们可以对它的返回值即std::future简单的调用get()实现同步等待甚至能获取任务的结果,但是std...多说一点,其实std::promise和std::future都是多线程状态共享的方案,这两种不存在高级低级,只有std::async和std::thread有点高级低级之分。...不过《C++标准库》中这样分类,加之std::future,std::promise分别用于std::async和std::thread的示例,我也只能照做了;)

2.5K40

STL的std::find和std::find_if

好的,给你讲讲 C++ STL 里的 std::find 和 std::find_if,它们都属于  头文件,都是用来在区间里查找元素的函数,但用途和灵活度稍有不同。... laststd::find_if查找第一个满足条件的元素区间 + 谓词函数(返回bool)指向满足条件的迭代器或 last好嘞,下面我帮你写个稍复杂的例子,结合 std::find 和 std::find_if... 展示它们的用法和适用场景差异,并顺便讲讲效率和实用上的区别。...用 std::find 查找名字等于 "Alice" 的员工 // std::find 只能直接比较整个元素,所以要传入 Employee 结构体 // 但Employee没有重载==,直接用...在效率上,std::find 和 std::find_if 都是线性扫描,时间复杂度是 O(n),没有本质差别,区别在于查找条件表达方式和灵活度。

28510
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    深入理解 C++ 中的 std::cref、std::ref 和 std::reference_wrapper

    深入理解 C++ 中的 std::cref、std::ref 和 std::reference_wrapper 在 C++ 编程中,有时候我们需要在不进行拷贝的情况下传递引用,或者在需要引用的地方使用常量对象...为了解决这些问题,C++ 标准库提供了三个有用的工具:std::cref、std::ref 和 std::reference_wrapper。这篇文章将深入探讨这些工具的用途、区别以及实际应用。...number std::endl; return 0; } 3. std::reference_wrapper:引用的包装器 std::reference_wrapper 是一个模板类...std::endl; std::cout std::endl; return 0; } 在这个示例中,std::reference_wrapper...允许我们将引用包装在容器中,然后通过 get() 方法来访问和修改原始对象的值。

    2.9K10

    std::thread崩溃的解法在这篇文章里了

    如果知道我会死在哪里,那我将永远不去那个地方 -查理 芒格 前言 C++11以来提供了C++原生的多线程std::thread,这极大的方便了多线程的书写。...std::thread具有非常高的优势,但是其也有自己的缺点,以下代码为例, void using_thread_with_no_join() { std::thread t{[](){ std...关注其构造函数:jthread不存在拷贝构造函数和拷贝赋值,存在移动构造函数和移动赋值运算符,即jthread不可拷贝但是可以转移。 2....std::this_thread::get_id(); }}; //正常输出,并未崩溃,某次执行结果如下 //sub jthread execuate, thread id35732...等原生std::thread的接口,故std::jthread可以无缝替换std::thread; 3. std::jthread支持外部请求中断,无需再向使用std::thread那样,提供一个标志位来作为线程启停的标志

    44410

    为什么std::string_view能解决std::string和char*的性能瓶颈?

    背景 std::string和char*存在瑕疵,才引入的std::string_view。...那std::string_view解决了std::string和char*的什么问题呢 不必要的内存复制:当 std::string 被传递给函数时,通常会发生一次深拷贝操作,即复制整个字符串内容。...std::string_view std::string_view 作为 C++17 引入的一种轻量级的新型字符串视图类,仅持有一个指向字符串数据的指针和一个表示字符串长度的整数。...通过避免不必要的内存复制和分配,std::string_view 提供了一种高效的方式来操作字符串数据。...然而,std::string_view 不负责内存管理,使用时需要小心数据的生命周期和悬空指针问题。通过合理运用 std::string_view,可以在确保性能的同时,提高程序的安全性和灵活性。

    56700

    C++多线程编程:深入剖析std::thread的使用方法

    四、线程封装封装线程,子类能继承,然后子类能实现具体的业务逻辑。创建线程通过new来实现,参数列表和使用构造函数创建是一样的。..., // 它具有static变量一样的初始化特征和生命周期,即使它不被声明为static。...通过灵活的线程管理和同步机制,可以有效地实现并发计算。...在 Linux 和其他 Unix-like 系统上使用 std::thread 时,通常需要链接 pthread 库,因为 C++11 的 std::thread 是基于 POSIX 线程库(pthread...-lpthread在使用某些高级的编译器(例如 g++ 版本 5 及更高版本)时,如果使用了 -std=c++11 或者更高版本的选项,编译器可能会自动链接 pthread 库,因此即使没有明确指定

    1.6K10

    高效的使用stl::map和std::set

    1、低效率的用法 // 先查找是否存在,如果不存在,则插入 if (map.find(X) == map::end()) // 需要find一次 {     map.insert(x); // 需要find...if (map.count(X) > 0) // 需要find一次 {     map.erase(X); // 需要find一次 } else {     // 不存在时的处理 } 2、高效率的用法...// 解决办法,充分利用insert和erase的返回值,将find次数降为1 map::size_type num_erased = map.erase(X); // 需要find一次 if (0...== num_erased) {     // 不存在时的处理 } else {     // 存在且删除后的处理 } pair result_inserted; result_inserted = map.insert...(X); if (result_inserted.second) {     // 不存在,插入成功后的处理 } else {     // 已经存在,插入失败后的处理     result_inserted.first

    3.1K20

    如何利用std::thread把类的成员函数当作线程函数并传递参数

    ; void Say() { std::cout std::endl; } }; class A { public: void Say() { std:...:cout std::endl; } void Start() { B b; std::thread t(&A::_start,this,b); t.detach...并且传递一个B的类对象b。大家仔细看看启动线程我在std::thread传递了3个参数,第一个就是函数,这里是类的成员函数_start,第二个类对象本身,第三个就是要传递给线程的参数。...总结如下: (1)类的函数要作为线程函数可以不用是static函数 (2)使用std::thread把类的成员函数作为线程函数,可以直接使用本类的成员函数 (3)启动线程时候要传递三个对应参数,如果你线程函数是...2个参数,则对应要传递4个参数给std::thread

    29210

    std和boost的function与bind实现剖析

    用过std和boost的function对象和bind函数的童鞋们都知道这玩意用起来腰不酸了,腿不疼了,心情也舒畅了。...先上一个简单得示例: std::string str; std::function func = std::bind(&std::string::at, &str); bool is_empty...看完源码以后,你会发现这里面有着一些很巧妙的设计。 因为std和boost的实现原理基本一样,std的代码可阅读性极差,所以这里就主要拿boost的源码来分析了。...这里在list的实现上boost和std有一点小小的差异。由于boost要兼容老版本的编译器,而老版本编译器是不支持动态模板参数的。...使用过boost的bind和function的童鞋应该看到过它里面的一个注意事项,就是如果bind的函数参数是引用类型,应该在执行bind函数时使用引用包装(boost::ref或者std::ref)。

    2.1K10

    std和boost的function与bind实现剖析

    用过std和boost的function对象和bind函数的童鞋们都知道这玩意用起来腰不酸了,腿不疼了,心情也舒畅了。...先上一个简单得示例: std::string str; std::function func = std::bind(&std::string::at, &str); bool is_empty...看完源码以后,你会发现这里面有着一些很巧妙的设计。 因为std和boost的实现原理基本一样,std的代码可阅读性极差,所以这里就主要拿boost的源码来分析了。...这里在list的实现上boost和std有一点小小的差异。由于boost要兼容老版本的编译器,而老版本编译器是不支持动态模板参数的。...使用过boost的bind和function的童鞋应该看到过它里面的一个注意事项,就是如果bind的函数参数是引用类型,应该在执行bind函数时使用引用包装(boost::ref或者std::ref)。

    1.4K30

    别再简单地问「std::vector 和 std::list 可以组合使用吗」:这是对 STL 设计哲学的误解

    一、前言 在 C++ 学习与实践的过程中,你可能听过或者问过这样一个问题: “std::vector 和 std::list 可以组合使用吗?” 表面上,这似乎是一个简单的问题。...STL(Standard Template Library)不是一组容器和算法的简单集合,而是一个以“可复用性”和“组合性”为核心的设计体系。 换句话说,STL 的灵魂就是“组合”。...操作复杂度的叠加效应 举个例子,如果你要在 vector> 中查找某个整数,时间复杂度为 O(n*m)。这显然不是一个好的通用结构。 那它有什么用? 并不是说它没有意义。...如果你的嵌套没有这些需求,那就要警惕——是否只是“能写出来”,而非“该写出来”。 2. 容器组合的替代方案 很多看似需要“容器套容器”的情况,其实可以用更简洁的方式表达。...这正是 C++ 从 STL 发展到 Ranges 的方向:更高层次的组合性与可复用性。 七、总结 回到最初的问题: “std::vector 和 std::list 可以组合使用吗?”

    9110

    C++中输出流的刷新问题和 endl和 n的区别

    《C++ Primer》第5版 P6中提到endl具有换行和刷新输出流两个作用,那么没有 endl是否还会将输出流中的内容输出到设备中,再刷新输出流呢?...endl; 在第2行前加入断点调试,程序输出显示 The test,说明没有 endl,也还是会刷新输出流。 继续运行程序,输出显示 The testThe test is over!。...说明在这个例子中,endl只体现出了换行的作用。会不会是书上说错了呢?并不是,虽然 endl具有刷新输出流的作用,但并不代表不使用 endl程序就不会刷新输出流了。...所以正如《C++ Primer》书中所写,为了避免出现没有刷新输出流的情况发生,在使用打印语句来调试程序时,一定要加入 endl或flush操纵符。...没有必要刷新输出流的时候应尽量使用 \n,比如对于无缓冲的流 cerr,就可以直接使用 \n。 最后,关于那个知乎回答,不同的编译器得到的结果居然会不一样。

    2.5K60
    领券