7.3 IO模型
回顧
為了更好地了解IO模型,我們需要事先回顧下:同步、異步、阻塞、非阻塞
同步
所謂同步,就是在發出一個功能調用時,在沒有得到結果之前,該調用就不會返回。
按照這個定義,其實絕大多數函數都是同步調用。
但是一般而言,我們在說同步、異步的時候,特指那些需要其他部件協作或者需要一定時間完成的任務。
異步
異步的概念和同步相對。
當一個異步功能調用發出后,調用者不能立刻得到結果。
當該異步功能完成后,通過狀態、通知或回調來通知調用者。
如果異步功能用狀態來通知,那么調用者就需要每隔一定時間檢查一次,效率就很低(有些初學多線程編程的人,總喜歡用一個循環去檢查某個變量的值,這其實是一 種很嚴重的錯誤)。
如果是使用通知的方式,效率則很高,因為異步功能幾乎不需要做額外的操作。
至于回調函數,其實和通知沒太多區別。
阻塞
阻塞調用是指調用結果返回之前,當前線程會被掛起(如遇到io操作)。
函數只有在得到結果之后才會將阻塞的線程激活。
有人也許會把阻塞調用和同步調用等同起來,實際上他是不同的。
對于同步調用來說,很多時候當前線程還是激活的,只是從邏輯上當前函數沒有返回而已。
非阻塞
非阻塞和阻塞的概念相對應,指在不能立刻得到結果之前也會立刻返回,同時該函數不會阻塞當前線程。
小結
總結
- 上一篇: 数据库开发——MySQL——慢查询优化
- 下一篇: 7.3.1 阻塞IO(blocking