同步和异步,以及阻塞和非阻塞已经被讨论了无数次。
同步和阻塞或许理解起来有相似的地方,其本质是两个概念。同步是指任务按照一定的顺序依次执行,即一个任务必须等待另一个任务完成后才能开始执行,同步操作通常体现在函数调用。阻塞是指程序在执行某些操作时暂时停止响应其他事件或请求,直到该操作完成或超时。如posix的网络api send()和rece()函数,不论socket是阻塞还是非阻塞状态,函数都是一个同步调用,区别是该调用是否产生阻塞。
在进行网络请求时如果使用了阻塞式 IO 操作,则当前线程将被挂起直到服务器响应完成;而如果使用了同步操作,则当前线程也需要等待服务器响应完成后才能继续执行下一行代码。
而异步api,通过需要通过注册回调函数,一旦条件触发,回调函数立刻执行,但该函数并不在主线程(或者说是调用该异步api线程),这样永远都不会造成调用该API阻塞。
文章参考与<零声教育>的C/C++linux服务期高级架构系统教程学习:C/C++Linux服务器开发/后台架构师【零声教育】-学习视频教程-腾讯课堂