C++ create_task详解

本文介绍C++中使用create_async与create_task构建异步操作的方法,通过示例代码展示了如何串接FirstAsync、SecondAsync及ThirdAsync三个异步任务,形成一个有序的异步任务链。
部署运行你感兴趣的模型镜像

C++ create_task详解

IAsyncOperation<T>^ asyncOperation = create_async( []() {
    return create_task(FirstAsync(...))
    .then( [](X val){
        return SecondAsync(val, ...);
    }).then( [](Y val)
        return ThirdAsync(val, ...);
    });

 

这段代码会执行FirstAsync->SecondAsync->ThirdAsync,最后返回的是 ThirdAsync的结果。

 

http://www.cnblogs.com/zjjcy/archive/2012/05/13/2489298.html

posted on 2016-03-04 17:32 jiahuafu 阅读(...) 评论(...) 编辑 收藏

您可能感兴趣的与本文相关的镜像

Python3.8

Python3.8

Conda
Python

Python 是一种高级、解释型、通用的编程语言,以其简洁易读的语法而闻名,适用于广泛的应用,包括Web开发、数据分析、人工智能和自动化脚本

### 关于 `threadpool_create` 函数 #### 使用说明 创建线程池通常涉及指定线程的数量以及可能的一些配置选项。虽然具体实现会有所不同,但一般情况下,创建线程池的过程包括初始化内部数据结构、启动一定数量的工作线程,并使这些线程进入等待状态以便接收任务。 #### 参数详解 基于常见的实践和提供的参考资料,假设有一个名为 `threadpool_create` 的函数用于创建线程池,则其参数可能如下: - **int thread_num**: 表示要在线程池中创建的线程数目。这决定了并发处理能力。 - **bool is_running (可选)**: 控制线程池的状态标志位,默认为 false 或 true 取决于设计需求。此参数决定新创建的线程是否会立即开始工作还是处于暂停状态直到被显式激活[^3]。 #### 实现方式 下面是一个简化版的 C++ 风格伪代码展示如何实现这样一个函数: ```cpp template<typename T> class threadpool { private: int _thread_num; bool _isrunning; public: /// @brief 创建一个新的线程池实例. /// /// @param[in] thread_num 要创建的工作线程数. /// @return 返回一个指向已分配内存区域的对象指针. static threadpool<T>* create(int thread_num) { auto pool = new threadpool<T>(thread_num); // 初始化其他必要的资源... return pool; } protected: /// 私有的构造方法防止外部直接实例化对象. threadpool(int thread_num): _thread_num(thread_num), _isrunning(false){ // 执行更多初始化操作... // 启动线程 for (size_t i = 0; i < _thread_num; ++i) { pthread_t tid; if(pthread_create(&tid, NULL, &worker, this)){ perror("pthread_create error"); exit(EXIT_FAILURE); } // 设置线程分离属性或其他必要设置... } } private: /// 工作线程执行的实际逻辑. static void* worker(void* arg){ threadpool<T>* pthis = reinterpret_cast<threadpool<T>*>(arg); while(true){ std::unique_lock<std::mutex> lock(pthis->_queue_mutex); pthis->_condition.wait(lock, [&]{return !pthis->_tasks.empty() || !pthis->_isrunning;}); if(!pthis->_isrunning && pthis->_tasks.empty()){ break; } task t = std::move(pthis->_tasks.front()); pthis->_tasks.pop(); lock.unlock(); t(); // 执行任务 } pthread_exit(NULL); } }; ``` 上述代码片段展示了如何在一个模板类 `threadpool` 中定义静态成员函数 `create` 来作为工厂方法负责构建新的线程池实例,并且包含了私有化的默认构造器以确保只能通过 `create` 方法来获得对象实例。另外还实现了 `_worker` 成员函数代表每个工作线程所执行的核心循环体[^1][^2]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

银狐游戏开发资源2

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值