加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

Swoole 中涉及的一些基本概念

发布时间:2020-12-13 21:04:46 所属栏目:PHP教程 来源:网络整理
导读:IO(Input/Output,输入输出) 在计算机中,输入 / 输出(即 IO)是指信息处理系统(比如计算机)和外部世界(可以是人或其他信息处理系统)的通信。输入是指系统接收的信号或数据,输出是指从系统发出的数据或信号。由于程序和运行时数据是在内存中驻留,由

IO(Input/Output,输入输出)

在计算机中,输入 / 输出(即 IO)是指信息处理系统(比如计算机)和外部世界(可以是人或其他信息处理系统)的通信。输入是指系统接收的信号或数据,输出是指从系统发出的数据或信号。由于程序和运行时数据是在内存中驻留,由 CPU 这个超快的计算核心来执行,涉及到数据交换的地方,通常是磁盘、网络等,就会有 IO 产生。

同步 - 异步

同步和异步是一种消息通信机制 (synchronous communication/asynchronous communication),关注点在于?被调用者返回?和?结果返回?之间的关系, 描述对象是被调用对象的行为。

# 同步(Synchronous):在发出一个同步调用时,在没有得到结果之前,该调用就不返回,等待返回结果才继续执行后续的操作。

# 异步( Asynchronous):发出调用,直接返回,不关心是否返回结果。异步可以通过状态、回调、 通知调用者结果,可以先去执行其他操作,然后等待通知再回来执行刚才没执行完的操作。
 

阻塞 - 非阻塞

阻塞和非阻塞是一种业务流程处理方式。关注点在于调用发生时?调用者状态?和?被调用者返回结果?之间的关系。 描述的是等待结果时候调用者的状态此时结果可能是同步返回的,也能是异步返回。

# 阻塞( Blocking ):在结果返回之前,当前线程被挂起,后续代码只有在结果返回后才能执行。

# 非阻塞( Nonblocking):在不能立刻获取结果前,该调用不会阻塞当前线程。

同步阻塞 - 同步非阻塞

实际编程中,通过线程实现进程的同步非阻塞,通过协程实现线程的同步非阻塞。

# 同步阻塞:打电话问老板有没有某书(调用),老板说查一下,让你别挂电话(同步),你一直等待老板给你结果,什么事也不做(阻塞)。

# 同步非阻塞:打电话问老板有没有某书(调用),老板说查一下,让你别挂电话(同步),等电话的过程中你还一边嗑瓜子(非阻塞)。

异步阻塞 - 异步非阻塞

?

# 异步阻塞:打电话问老板有没有某书(调用),老板说你先挂电话,有了结果通知你(异步),你挂了电话后(结束调用),除了等老板电话通知结果,什么事情也不做(阻塞)。

?

# 异步非阻塞:打电话问老板有没有某书(调用),老板说你先挂电话,有了结果通知你(异步),你挂电话后(结束调用),一遍等电话,一遍嗑瓜子。(非阻塞)

?

IO 模型

5 种 I/O 模型:

  • 阻塞式 I/O
  • 非阻塞式 I/O
  • I/O 复用(select,poll,epoll…)
  • 信号驱动式 I/O(SIGIO)
  • 异步 I/O(POSIX 的 aio_系列函数)

IO 模型的具体解释可以参考?linux 五种 IO 模型

参考资源

    • 链接:juejin.im/post/5c725dbe51882575e37...
      链接:phenix3443.github.io/notebook/soft...
      • 更多PHP内容请访问:

        腾讯T3-T4标准精品PHP架构师教程目录大全,只要你看完保证薪资上升一个台阶(持续更新)

?

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读