std::async简单使用

2023-09-22 12:00:41

std::async介绍并使用

std::async是C++11引入的一个用于异步执行函数或函数对象的工具。它可以用于并行地执行函数,并在需要时获取函数的返回值。下面是一个简单的示例,演示了如何使用std::async

#include <iostream>
#include <future>

// 一个简单的函数,将两个整数相加并返回结果
int Add(int a, int b) {
    return a + b;
}

int main() {
    // 使用std::async异步执行函数
    std::future<int> future_result = std::async(Add, 5, 3);

    // 在需要时获取函数的返回值
    int result = future_result.get();

    std::cout << "Result: " << result << std::endl;

    return 0;
}

在上面的示例中,我们首先定义了一个简单的函数Add,它将两个整数相加并返回结果。然后,我们使用std::async来异步执行Add函数,传递两个整数参数(5和3)。std::async返回一个std::future对象,表示异步任务的未来结果。最后,我们使用get函数从std::future中获取异步任务的结果。

需要注意以下几点:

  1. std::async会创建一个新的线程或使用线程池来执行函数,具体取决于实现。

  2. 使用get函数获取结果时,如果异步任务尚未完成,调用将阻塞,直到结果可用。

  3. 可以通过在std::async的第一个参数中传递std::launch::asyncstd::launch::deferred来控制任务的执行方式。默认情况下,它使用实现定义的默认策略。

请注意,std::async的用法可能因C++标准库的实现而异,某些实现可能不支持线程池,因此可能在不同平台上表现不同。还要注意,std::async的性能开销较高,对于某些简单的任务,使用std::thread等其他方法可能更合适。

std::thread和std::async区别

std::threadstd::async都是C++11引入的多线程编程工具,用于创建并发执行的线程。它们之间的主要区别在于用法和返回结果的处理方式。

  1. std::thread

    • std::thread用于手动创建线程。您需要显式创建线程对象并将函数或函数对象传递给它,然后调用std::threadjoindetach函数来管理线程的生命周期。

    • std::thread不提供一种直接方式来获取线程函数的返回值,因此通常需要使用共享数据结构(如std::mutexstd::condition_variable)来在线程之间传递结果。

    • 下面是一个简单的示例,演示了std::thread的用法:

    #include <iostream>
    #include <thread>
    
    void ThreadFunction(int value) {
        std::cout << "Thread value: " << value << std::endl;
    }
    
    int main() {
        std::thread t(ThreadFunction, 42);
        t.join(); // 等待线程执行完毕
        return 0;
    }
  2. std::async

    • std::async用于创建异步任务,它返回一个std::future对象,该对象表示异步任务的未来结果。您可以使用std::futureget函数来获取异步任务的结果,这将会阻塞,直到结果可用。

    • std::async可以选择性地指定任务的执行策略(std::launch::asyncstd::launch::deferred)。默认情况下,它使用实现定义的默认策略。

    • 以下是一个简单的示例,演示了std::async的用法:

    #include <iostream>
    #include <future>
    
    int Add(int a, int b) {
        return a + b;
    }
    
    int main() {
        std::future<int> future_result = std::async(Add, 5, 3);
        int result = future_result.get(); // 获取异步任务的结果
        std::cout << "Result: " << result << std::endl;
        return 0;
    }

总结:

  • std::thread适用于手动管理线程的生命周期,适用于需要显式控制线程的情况。

  • std::async适用于创建异步任务,它提供了更方便的方法来获取线程函数的返回值,适用于需要获取任务结果的情况。

选择使用哪个取决于您的需求,如果您需要更多的线程控制和管理,可以使用std::thread,如果您更关心获取任务结果,可以使用std::async

更多推荐

美团接口自动化测试实践

一、概述1.1接口自动化概述众所周知,接口自动化测试有着如下特点:低投入,高产出。比较容易实现自动化。和UI自动化测试相比更加稳定。如何做好一个接口自动化测试项目呢?我认为,一个“好的”自动化测试项目,需要从**“时间”、“人力”、“收益”**这三个方面出发,做好“取舍”。不能由于被测系统发生一些变更,就导致花费了几个

【Vue】深究计算和侦听属性的原理

hello,我是小索奇,精心制作的Vue系列教程持续更新哈,涵盖大量的经验和示例,由浅入深进行讲解,想要学习&巩固&避坑就一起学习吧~计算和侦听属性计算属性重点概要定义:要用的属性不存在,需要通过已有属性计算得来原理:底层借助了Objcet.defineproperty()方法提供的getter和setter来计算属性

git的使用

Git是一种版本控制系统,它可以跟踪文件的更改历史。以下是Git的基本概念和使用方式:仓库(Repository):Git用仓库来存储文件和版本历史。可以在本地电脑上创建一个仓库,或者使用GitHub等在线仓库托管服务。提交(Commit):Git通过提交来记录文件更改历史。每次提交都包含一条消息,描述本次更改的内容。

以京东平台为例写一份电商平台API接口文档

公共参数请求地址:申请调用KEY地址名称类型必须描述keyString是调用key(必须以GET方式拼接在URL中)secretString是调用密钥api_nameString是API接口名称(包括在请求地址中)[item_search,item_get,item_search_shop等]cacheString否[

关于什么是框架

框架(Framework)是一个框子——指其约束性,也是一个架子——指其支撑性。IT语境中的框架,特指为解决一个开放性问题而设计的具有一定性的支撑结构。在此结构上约束可以根据具体问题扩展、安插更多的组成部分,从而更迅速和方便地构建完整的解决问题的方案。目前还没看到什么有趣的个人化解释,可能是因为要解决都复杂到设计出框架

u盘上面 安装 ubuntu 系统

u盘上面安装ubuntu系统下载一个Ubuntu22.04.3LTS桌面版https://ubuntu.com/download/desktop找到一个U盘参考文章:把Ubuntu装到U盘里随身携带,并同时支持BIOS和UEFI启动https://www.luogu.com.cn/blog/GGAutomaton/po

消息队列-rabbitMq

消息队列(MQ)到底能干什么?MQ全称为MessageQueue,也就是消息队列,是应用程序和应用程序之间的通信方法。在微服务盛行的当下,MQ被使用的也是越来越多,一般常用来进行业务异步解耦、解耦微服务、流量削峰填谷、消息分发、分布式事务的数据一致性。1、业务异步解耦最常见的场景就是用户注册之后,需要发送注册短信、邮件

Spring Boot业务系统如何实现海量数据高效实时搜索

1.概述我们都知道随着业务系统的发展和使用,数据库存储的业务数据量会越来越大,逐渐成为了业务系统的瓶颈。在阿里巴巴开发手册中也建议:单表行数超过500万行或者单表容量超过2GB才推荐进行分库分表,如果预计三年后数据量根本达不到这个级别,请不要在创建表时就分库分表。数据库最终都是存储在磁盘上,随着数据量变大,会导致数据操

TCP IP网络编程(六) 基于UDP的服务器端、客户端

文章目录一、理解UDP1.UDP套接字的特点2.UDP内部工作原理3.UDP的高效使用二、实现基于UDP的服务器端、客户端1.UDP中的服务端和客户端没有连接2.UDP服务器端和客户端均只需要一个套接字3.基于UDP的数据I/O函数4.基于UDP的回声服务器端、客户端5.UDP客户端套接字的地址分配三、UDP的数据传输

2023研究生数学建模D题思路代码 区域双碳目标与路径规划研究

D题思路代码区域双碳目标与路径规划研究完整解题思路可看视频:2023华为杯研赛D题区域双碳目标与路径规划研究(附代码+全保姆教程)_哔哩哔哩_bilibili​www.bilibili.com/video/BV1Cm4y157CH/?spm_id_from=333.999.0.0问题一:区域碳排放量以及经济、人口、能源

Spring Security 用了那么久,你对它有整体把控吗?

文章目录1.ServletFilter:守门人的角色2.DelegatingFilterProxy:桥接Servlet和Spring的神器3.FilterChainProxy:SpringSecurity过滤器链的管家3.SecurityFilterChain:Security过滤器的串绳4.SpringSecurit

热文推荐