V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
twogoods
V2EX  ›  问与答

关于异步编程的好处

  •  
  •   twogoods · 2018-01-22 11:19:41 +08:00 · 3158 次点击
    这是一个创建于 2479 天前的主题,其中的信息可能已经有所发展或是发生改变。

    类似 nodejs,假设如果业务上可并行的代码比较少(个人感觉大量的业务代码就是并行度不高的),全都是下一步操作要等上一步的结果,代码里有不少 async/await,那可以说异步编程也是无法降低响应时间的.那异步编程带来了什么好处?

    受限于机器硬件资源,单台服务器所能支撑的线程数是存在一个上限的,假设为 T,那么应用同时能处理的请求数(吞吐量)必然也不会超过 T。如果运行在像 Netty 这样的异步容器中,无论有多少个请求,用于处理请求的线程数是相对固定的,因此最大吞吐量就有可能超过 T。

    上面这段那 java 来举例,说明异步编程未必能带来响应时间上的提升,但能提高吞吐量。
    我不是很理解异步编程提高吞吐量这个点?大家能给能举一个通俗点的例子吗?也可以谈谈大家对异步编程好处的理解。

    5 条回复    2018-01-22 13:55:57 +08:00
    hellommd
        1
    hellommd  
       2018-01-22 11:40:59 +08:00
    https://msdn.microsoft.com/zh-cn/magazine/dn802603.aspx

    web 方面的异步编程,可以看看微软这边文章,写得很详细了。

    与同步比较,优缺点。
    gouchaoer
        2
    gouchaoer  
       2018-01-22 11:45:18 +08:00 via Android
    callback hell 有啥好处。。。io 异步是方案,协程也是方案,基于 yield 的半协程次之
    tailf
        3
    tailf  
       2018-01-22 13:45:56 +08:00
    异步编程好处我感觉不太明显,坏处却是大大的有。
    SuperMild
        4
    SuperMild  
       2018-01-22 13:54:58 +08:00
    总体感觉异步为主的系统更容易提高健壮性,因为可以轻易忽略被卡住的部分(比如网络不通、文件被锁定等等),系统的其他部分照常运作。对于被卡住的部分,可以设定超时返回错误信息。用户的体验比较好。当然同步为主的系统也可以做到,但异步实现更轻松。
    QAPTEAWH
        5
    QAPTEAWH  
       2018-01-22 13:55:57 +08:00
    “受限于机器硬件资源,单台服务器所能支撑的线程数是存在一个上限的,假设为 T,那么应用同时能处理的请求数(吞吐量)必然也不会超过 T。如果运行在像 Netty 这样的异步容器中,无论有多少个请求,用于处理请求的线程数是相对固定的,因此最大吞吐量就有可能超过 T。”

    这些话是扯蛋的。

    理解异步意义的关键字
    - IO 密集与 CPU 密集的区别
    - 线程切换开销
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2942 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 14:50 · PVG 22:50 · LAX 06:50 · JFK 09:50
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.