首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

C++11异步编程(std::async, std::future, std::packaged_task, std::promise)

在之前我们都是通过thread去创建一个子线程,但是如果我们要得到这个子线程所返回的结果,那么可能就需要用全局变量或者引用的方法来得到结果,这样或多或少都会不太方便,那么async这个函数就可以将得到的结果保存在...async比起thread来说可以对线程的创建又有了更好的控制,比如可以延迟创建。下面先介绍一下std::future, std::packaged_task, std::promise。...它的实现方法有两种,一种是std::launch::async,这个是直接创建线程,另一种是std::launch::deferred,这个是延迟创建线程(当遇到future.get或者future.wait...的时候才会创建线程),这两个参数是std::async的第一个参数,如果没有使用这个两个参数,也就是第一个参数为空的话,那么第一个参数默认为std::launch::async | std::launch...当执行到fu.get才开始创建线程 std::future fu = std::async(std::launch::deferred, fun, 1); std::cout << fu.get

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

Rust 视界 | async-std 团队发布 Async Http 套件

Async HTTP async-std 团队的主要开发者yoshuawuyts,联合「 协议实验室」 和 「微软」的另外两人,共同发布了 async http 套件。...这些trait 的目的是表示解析的字节,通常直接来自IO层(例如来自套接字或文件)。 Rust流具有其他语言的一些最佳特性。...对于「分裂生态」言论的回应 介于Rust社区有人一直在说「async-std vs tokio」导致生态分裂的言论,该文章里也有回应: 在公共领域分享发现并不是分裂行为 async-std团队只是在尝试和改进新的解决方案...async-std 和 tokio 都是不错的代表。) 下一步动作 1. 讨论 async-h2 中。 2. 等待 tide 发布 1.0 。...tide 是一个基于 async-std 的异步 Web 开发框架,目前tide 已经 0.6 版本了。

1.9K20

CC++开发基础——std::future与async异步编程

可以使用std::launch给std::async传参,std::launch可以控制是否给std::async创建新线程。...通过传参std::launch来让std::async选择指定方式执行线程函数的方法有三种: std::launch::async:创建新线程,异步执行线程函数。...thread. 28 2.std::asyncstd::thread的区别 std::thread直接创建线程,而std::async异步创建一个任务,这个任务可以创建新线程,也可以不创建线程,可以避免占用系统资源...由于std::async不一定会创建新线程,因此,当系统内存资源不足的时候,继续运行std::thread会使系统崩溃,而std::async此时不会创建新线程,避免了系统崩溃。...std::thread创建的线程不容易获取线程函数的返回值,std::async执行完返回一个std::future对象,可以很容易获取线程函数的返回值。

47110

【C++11】std::async函数介绍及问题梳理

std::async 中,任务可能在一个新线程中执行,也可能在当前线程中执行。...如果任务在新线程中执行,并且在该新线程中发生了内存分配失败,那么系统会终止整个程序,而不是将异常传递回调用 std::async 的地方【这是因为线程的异常不能跨线程传递】 这是因为C++的异常处理机制不能跨线程传播...如果异常发生在 std::async 创建的新线程中,并且在那里没有被捕获,那么整个线程会终止,但异常不会被传递回调用 std::async线程。...2.3 std::async 如果系统线程不够有没有可能异常 这种情况下,std::async 可能会抛出 std::system_error 异常。...在使用 std::async 时,如果系统线程不够,可能会导致无法启动新线程而引发异常【这通常不是由于内存不足引起的,而是由于达到了系统对同时运行线程数量的限制】 【示例】系统线程不够抛异常 #include

34010

C++ std::thread线程详解

C++ 11 取消了所有这些,并给了我们 std::thread。线程类和相关函数在头文件中定义。 类thread表示单个执行线程线程在构建关联的线程对象时立即开始执行。...其定义用于观察和管理应用程序中的执行线程的对象。 2. 创建一个thread std::thread 是 C++ 中表示单个线程线程类。...等待线程执行完毕 线程启动后,我们可能需要等待线程完成,然后才能采取一些操作。要等待线程,请使用 std::thread::join() 函数。...注:std::thread::get_id返回线程的 id,即返回标识与 *this 关联的线程std::thread::id。 如果线程是 joinable ,并不意味着它已完成。它可能仍在运行。...线程任务的移动和交换 没有两个 std::thread 对象会表示同一执行线程,因为 std::thread 是可移动构造且可移动赋值,但不是可复制构造或可复制赋值的。

98920

新的线程:C++20 std::jthread

1. std::jthread是什么 类jthread表示单个执行线程。它拥有通常同 std::thread 的行为,除了jthread在析构时自动再结合,而且能在具体情况下取消/停止。 2....为什么要引入jthread std::jthread 在std::thread 基础上,增加了能够主动取消或停止线程执行的新特性。...与 std::thread 相比,std::jthread 具有异常安全的线程终止流程,并且在大多数情况下可以替换它,只需很少或无需更改代码。...在我们进入细节之前,先说一说std::thread 的缺陷:std::jthread 使用的时候需要通过join()来完成等待线程结束,继续join()后语句的执行,或者调用detach()来让线程与当前线程分离...(): true Joinable std::thread 3.2 线程中断 对于线程中断,std::jthread主要引入以下三个停止信号处理: get_stop_source() :返回与线程的停止状态关联的

22920

@Async应用自定义线程

@Async应用自定义线程池 自定义线程池,可对系统中线程池更加细粒度的控制,方便调整线程池大小配置,线程执行异常控制和处理。...在设置系统自定义线程池代替默认线程池时,虽可通过多种模式设置,但替换默认线程池最终产生的线程池有且只能设置一个(不能设置多个类继承AsyncConfigurer)。...通过查看Spring源码关于@Async的默认调用规则,会优先查询源码中实现AsyncConfigurer这个接口的类,实现这个接口的类为AsyncConfigurerSupport。...,Spring通过beanFactory.getBean(TaskExecutor.class)先查看是否有线程池,配置时,通过beanFactory.getBean(DEFAULT_TASK_EXECUTOR_BEAN_NAME...@Async注解,使用系统默认或者自定义的线程池(代替默认线程池)。

2.4K00

dotnet 警惕 async void 线程顶层异常

在 dotnet 应用里面,如果一个线程顶层出现捕获异常,则应用进程将会被认为出现异常状态而退出。...通常来说就是捕获异常导致进程闪退 在 dotnet 里面,有一个隐藏的陷阱,那就是 async void 将会在没有线程同步上下文的情况下,被当成线程顶层。...如果在 async void 里面发生任何捕获的异常,严重的话将会导致进程闪退 如以下代码,在当前执行线程没有线程同步上下文的情况下,抛出的异常将会让进程闪退 async void Foo() {...将 async void 改为 async Task 然后抛出捕获异常,此时如果方法返回的 Task 没有被任何等待,将会在 Task 对象被 GC 时进入 TaskScheduler.UnobservedTaskException...通过本文可以了解到,在 dotnet 里面隐藏了 async void 和异步无返回值事件或委托加等逻辑里面可能出现的因为捕获异常导致的进程闪退问题。

17740
领券