基于事件驱动的并发编程

作者: 高广超 | 来源:发表于2017-04-28 10:46 被阅读226次
  • 同步与异步
    • 同步和异步关注的是消息通信机制 (synchronous communication/ asynchronous communication)
    • 所谓同步,就是在发出一个调用时,在没有得到结果之前,该调用就不返回。但是一旦调用返回,就得到返回值了。换句话说,就是由调用者主动等待这个调用的结果。
    • 而异步则是相反,调用在发出之后,这个调用就直接返回了,所以没有返回结果。换句话说,当一个异步过程调用发出后,调用者不会立刻得到结果。而是在调用发出后,被调用者通过状态、通知来通知调用者,或通过回调函数处理这个调用。
  • 阻塞与非阻塞
    • 阻塞和非阻塞关注的是程序在等待调用结果(消息,返回值)时的状态.
    • 阻塞调用是指调用结果返回之前,当前线程会被挂起。调用线程只有在得到结果之后才会返回。
    • 非阻塞调用指在不能立刻得到结果之前,该调用不会阻塞当前线程。
  • 一般来说I/O模型可以分为:同步阻塞,同步非阻塞,异步阻塞,异步非阻塞IO
    • 同步阻塞IO:
      • 在此种方式下,用户进程在发起一个IO操作以后,必须等待IO操作的完成,只有当真正完成了IO操作以后,用户进程才能运行。JAVA传统的IO模型属于此种方式!
    • 同步非阻塞IO:
      • 在此种方式下,用户进程发起一个IO操作以后边可返回做其它事情,但是用户进程需要时不时的询问IO操作是否就绪,这就要求用户进程不停的去询问,从而引入不必要的CPU资源浪费。其中目前JAVA的NIO就属于同步非阻塞IO。
    • 异步阻塞IO:
      • 此种方式下是指应用发起一个IO操作以后,不等待内核IO操作的完成,等内核完成IO操作以后会通知应用程序,这其实就是同步和异步最关键的区别,同步必须等待或者主动的去询问IO是否完成,那么为什么说是阻塞的呢?因为此时(通知)是通过select系统调用来完成的,而select函数本身的实现方式是阻塞的,而采用select函数有个好处就是它可以同时监听多个文件句柄(就绪的没有就绪的都有监听,epoll是select的替代方式,只监听就绪的文件句柄),从而提高系统的并发性!
    • 异步非阻塞IO:
      • 在此种模式下,用户进程只需要发起一个IO操作然后立即返回,等IO操作真正的完成以后,应用程序会得到IO操作完成的通知,此时用户进程只需要对数据进行处理就好了,不需要进行实际的IO读写操作,因为真正的IO读取或者写入操作已经由内核完成了。目前Java中还没有支持此种IO模型。
  • 异步事件驱动
    • 如果我们的业务逻辑处理使用异步事件驱动(Reactor)的方式,而又需要在本次请求中需要返回请求结果,此时属于同步获取返回值,因此此时我们只能使用阻塞异步或者“并发”“同步”的方式。
    • 如果该次请求不需要同步获取返回值,此时我们即可使用阻塞异步(Reactor)方式,也可以结合使用DeferredResult异步结果返回。

欢迎关注 高广超的简书博客 与 收藏文章 !
欢迎关注 头条号:互联网技术栈

个人介绍:

高广超 :多年一线互联网研发与架构设计经验,擅长设计与落地高可用、高性能互联网架构。

本文首发在 高广超的简书博客 转载请注明!

image.png

相关文章

  • 基于事件驱动的并发编程

    同步与异步同步和异步关注的是消息通信机制 (synchronous communication/ asynchro...

  • 利用数据驱动模式编写复杂样式的UITableView

    数据驱动是一种思想,数据驱动型编程是一种编程范式。基于数据驱动的编程,基于事件的编程,以及近几年业界关注的响应式编...

  • 并发编程

    并发编程三种构造并发程序的方式:基于进程的并发编程、基于IO多路复用的并发编程、基于线程的并发编程1、 基于进程...

  • 事件驱动编程

    看完公司的基于Netty的游戏框架,框架中用到了多态,函数式编程和事件驱动编程,第一次看到事件驱动的时候,就想到跟...

  • 高并发

    分布式 cache 事件驱动-异步处理 高并发编程【锁优化篇】https://zhuanlan.zhihu.com...

  • Spring5IOC容器解析——事件监听机制

    一、事件驱动模型简介 事件驱动模型,也即是我们通常说的观察者。基于发布-订阅模式的编程模型。 概念 定义对象间的一...

  • Java8 - Lambda

    函数式编程在并发和事件驱动编程中优势明显。所以Java8引入了Lambda表达式的概念。 面向对象编程与函数式...

  • 2018-01-26

    ## 并发的驱动力 并发编程复兴的主要驱动力来自于“多核危机”。 ## 并发与并行 并发程序含有多个逻辑上的独立执...

  • NIO编程

    Unblocking IO(New IO): 同步非阻塞的编程方式。NIO本身是基于事件驱动思想来完成的,其主要想...

  • Python并发编程-事件驱动模快

    一、事件驱动模型介绍 1、传统的编程模式 例如:线性模式大致流程 开始--->代码块A--->代码块B--->代码...

网友评论

    本文标题:基于事件驱动的并发编程

    本文链接:https://www.haomeiwen.com/subject/bbuozttx.html