同步、异步,阻塞、非阻塞
异步:异步就是和同步的概念是相对应的。当一个异步过程调用发生后,调用者不能立刻得到结果,该调用就返回。实际处理这个调用的部件在完成后,通过状态、通知和回调函
数来通知调用者。
阻塞:阻塞调用是指调用过程返回之前,当前线程会被挂起(线程进入非可执行状态,在这个状态下,cpu不会给线程分配时间片,即线程暂停执行)。函数只有在得到结果之后
才会返回。
非阻塞:非阻塞为是相对与阻塞的,指在不能立刻得到返回结果之前,该函数不会阻塞当前的线程,而会立即返回。
(1)同步,就是我调用一个功能,该功能没有结束之前,我死等结果。
(2)异步,就是我调用一个功能,不需要知道该功能的结果,该功能有结果后通知我。
(3)阻塞,就是调用我,我没有接收完数据或者没有得到结果之前,我不会返回。
(4)非阻塞,就是调用我,我立即返回,通过select通知调用者。
同步IO和异步IO的区别就在于:数据拷贝的时候进程是否阻塞
阻塞IO和非阻塞IO的区别就在于:应用程序的调用是否立即返回
阻塞和非阻塞是指当进程访问的数据如果尚未就绪,进程是否需要等待,简单说这相当于函数内部的实现区别,也就是未就绪时是直接返回还是等待就绪 ; 而同步和异步是指访问数据
的机制,同步一般指主动请求并等待I/O操作完毕的方式,当数据就绪后在读写的时候必须阻塞(区别就绪与读写二个阶段,同步的读写必须阻塞),异步则指主动请求数据后便可以继续处
理其它任务,随后等待I/O,操作完毕的通知,这可以使进程在数据读写时也不阻塞(等待"通知")。
注意:在这里可能会把同步和阻塞等同起来,实际上两者是不同的。对于同步调用,很多时候当前线程还是激活的,只是从逻辑上当前函数没有返回而已。而阻塞线程进入非可执
行状态,在这个状态下,cpu不会给线程分配时间片,即线程暂停执行。
同步和异步仅仅是关于所关注的消息如何通知的机制。同步的情况下,是由处理消息者自己去等待消息是否被触发,而异步的情况下是由触发机制来通知处理消息者。阻塞和非阻塞应
该是发生在消息的处理的时刻。阻塞其实就是等待,发出通知,等待结果完成。非阻塞属于发出通知,立即返回结果,没有等待过程。