码迷,mamicode.com
首页 > 其他好文 > 详细

异步编程的优势和难点

时间:2018-02-02 14:10:01      阅读:166      评论:0      收藏:0      [点我收藏+]

标签:原则   c++   catch   bsp   方案   tab   异步编程   status   proc   

 

传统解决方式:

  • 多线程: 多线程上下文切换问题,锁问题,同步问题
  • c/c++手动完成:门槛较高

node基于事件的非阻塞编程

优势:

  • 非阻塞I/O可以使CPU与I/O并不依赖,可以更大程度的利用资源

  • 对于网络应用,并行带来的优势更大,利于分布式和云的应用

  • 由于调用了c/c++的扩展模块,node的性能较高

难点:

  1. 异常处理

    1. 不能使用try/catch/final对异步编程进行异常处理,因为发生异常的代码不一定在本次事件循环中执行,所以有可能捕捉不到

       解决方法:给callback第一个参数传递是否报错,未报错则返回null报错则返回error对象。

       原则:在编写自定义异步方法时,必须执行调用者传入的参数,必须正确返回参数callback(null, results)

    2. 对用户调用的回调函数进行try/catch

      try {
        	req.body = JSON.parse(buf, options.reviver);
        	callback();
      } catch (err){
       	err.body = buf;
        	err.status = 400;
      	callback(err);		
      }

      这样就会导致callback中出错也会被catch到,导致调用两次callback

      解决方法:

      try {
        	req.body = JSON.parse(buf, options.reviver);
      } catch (err){
       	err.body = buf;
        	err.status = 400;
      	callback(err);		
      }  	
      callback();
  2. 阻塞代码:不要用while来阻塞,用setTimeout

  3. 多线程:用child_process

  4. 回调过多 解决方案异步编程的优势和难点-多异步之间的协作方案

 

异步编程的优势和难点

标签:原则   c++   catch   bsp   方案   tab   异步编程   status   proc   

原文地址:https://www.cnblogs.com/ranjianxi/p/8404539.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!