同步/异步, 阻塞/非阻塞分别是什么? 本篇文章想简单谈谈.
同步/异步
当请求一个方法时, 调用者需要等待该方法执行完成, 且该方法会返回执行结果, 则对于调用者来说就是"同步"的.
当请求一个方法时, 调用者不需要等待该方法执行完成, 该方法被调用后会立即返回, 注意该方法返回的不是执行结果, 比如返回None(NULL), 则对于调用者来说便是"异步"的.
同步/异步关注的是消息通信机制.
阻塞/非阻塞
当请求一个方法时, 调用者在得到调用结果之前, 调用者进程会被挂起, 便是"阻塞"的.
当请求一个方法时, 调用者在得到调用结果之前, 还能继续执行其他命令, 便是"非阻塞"的.
阻塞/非阻塞关注的是程序在等待调用结果时的状态.
同步阻塞, 同步非阻塞, 异步
同步/异步, 阻塞/非阻塞可能并不是同一概念, 之间可以两两组合, 形成"同步阻塞", "同步非阻塞", "异步非阻塞"三种, 注意是没有"异步阻塞"的. 下面以"你打算烧开一壶水"来举例:
同步阻塞: 你在水壶旁等着水烧开, 之间什么也不做.
同步非阻塞: 你可以离开水壶去做其他事, 但需要时不时回来看一眼, 直至水烧开.
异步: 你可以离开水壶去做其他事, 水烧开后, 水壶会通知你.
文中应该还有不当之处, 我会持续修改, 感谢~