[Modern C++]现代C++中的异步操作


背景

老实说,C++11中对异步的支持不必Python和JavaScript弱。

实现(代码)

 
 
  1. #include <iostream> 
  2. #include <vector> 
  3. #include <algorithm> 
  4. #include <future> 
  5.  
  6. template <typename RAIter> 
  7. int parallel_sum(RAIter front, RAIter beg, RAIter end
  8.     auto len = end - beg; 
  9.     if (len < 1000) 
  10.     { 
  11.         char out[50]; 
  12.         sprintf(out"Calculate from %d to %d\n", beg - front, end - front); 
  13.         std::cout << out
  14.         return std::accumulate(beg, end, 0); 
  15.     } 
  16.  
  17.     RAIter mid = beg + len / 2; 
  18.     auto handle_right = std::async(std::launch::async, 
  19.                              parallel_sum<RAIter>, front, mid, end); 
  20.     auto handle_left = std::async(std::launch::async, 
  21.                              parallel_sum<RAIter>, front, beg, mid); 
  22.     return handle_left.get() + handle_right.get(); 
  23.  
  24. int main() 
  25.     std::vector<int> v(20000, 1); 
  26.     std::cout << "The sum is " << parallel_sum(v.begin(), v.begin(), v.end()) << '\n'

输出

可能一

 
 
  1. Calculate from 8125 to 8750                                                                                                                
  2. Calculate from 18125 to 18750                                                                                                              
  3. Calculate from 10625 to 11250                                                                                                              
  4. Calculate from 2500 to 3125                                                                                                                
  5. Calculate from 13750 to 14375                                                                                                              
  6. Calculate from 5000 to 5625                                                                                                                
  7. Calculate from 1250 to 1875                                                                                                                
  8. Calculate from 3750 to 4375                                                                                                                
  9. Calculate from 16250 to 16875                                                                                                              
  10. Calculate from 17500 to 18125                                                                                                              
  11. Calculate from 10000 to 10625                                                                                                              
  12. Calculate from 625 to 1250                                                                                                                 
  13. Calculate from 18750 to 19375                                                                                                              
  14. Calculate from 15625 to 16250                                                                                                              
  15. Calculate from 3125 to 3750                                                                                                                
  16. Calculate from 12500 to 13125                                                                                                              
  17. The sum is 20000  

可能二

 
 
  1. Calculate from 1875 to 2500 
  2. Calculate from 3750 to 4375  
  3. Calculate from 8750 to 9375  
  4. Calculate from 7500 to 8125  
  5. Calculate from 15000 to 15625  
  6. Calculate from 10000 to 10625  
  7. Calculate from 1250 to 1875  
  8. Calculate from 6875 to 7500  
  9. Calculate from 0 to 625 
  10. Calculate from 3125 to 3750  
  11. Calculate from 5625 to 6250  
  12. Calculate from 5000 to 5625  
  13. Calculate from 6250 to 6875  
  14. Calculate from 2500 to 3125  
  15. The sum is 20000 

可能.........

注意

如果在输出中间信息的时候不先现在字符串里输出会很乱,因为同一行cout输出不同项的操作不是原子的,中间可能会转到其他线程去。


作者:佚名

来源:51CTO

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值