同步與異步
同步和異步關(guān)注的是消息通信機(jī)制.
同步異步指的是調(diào)用者與被調(diào)用者兩者之間的關(guān)系攻冷,而不是經(jīng)常容易誤解的多個被調(diào)用者之間的關(guān)系。
同步
所謂同步题诵,就是在發(fā)出一個功能調(diào)用時洁仗,在沒有得到結(jié)果之前,該調(diào)用就不會返回性锭,一旦調(diào)用返回赠潦,就得到返回值了。
換句話說,就是由調(diào)用者主動等待這個調(diào)用結(jié)果.按照此定義草冈,其實(shí)絕大多數(shù)函數(shù)都是同步調(diào)用她奥。但是一般而言,我們在說同步怎棱、異步的時候哩俭,特指那些需要其他程序或者IO協(xié)作或者需要一定時間完成的任務(wù)。
舉例:
#1. multiprocessing.Pool下的apply #發(fā)起同步調(diào)用后拳恋,
就在原地等著任務(wù)結(jié)束凡资,根本不考慮任務(wù)是在計算還是在io阻塞,總之就是一股腦地等任務(wù)結(jié)束
#2. concurrent.futures.ProcessPoolExecutor().submit(func,).result()
#3. concurrent.futures.ThreadPoolExecutor().submit(func,).result()
簡單一句話就是:調(diào)用者調(diào)用了一個功能時調(diào)用者要等著被調(diào)用者執(zhí)行完畢谬运,無論被調(diào)用者是在阻塞還是非阻塞狀態(tài),才能繼續(xù)進(jìn)行自己的任務(wù)
異步
異步的概念和同步相對隙赁。調(diào)用在發(fā)出之后,這個調(diào)用就直接返回了,所以沒有返回結(jié)果.換句話說當(dāng)一個異步功能調(diào)用發(fā)出后,調(diào)用者不能立刻得到結(jié)果梆暖。但是這個時候被調(diào)用者可以去執(zhí)行下面的代碼而不是一味的等待伞访。
另外需要強(qiáng)調(diào)的一點(diǎn):
當(dāng)該異步功能完成后,被調(diào)用者可以通過狀態(tài)轰驳、通知或回調(diào)來通知調(diào)用者厚掷。如果異步功能用狀態(tài)來通知,那么調(diào)用者就需要每隔一定時間檢查一次级解,效率就很低(有些初學(xué)多線程編程的人冒黑,總喜歡用一個循環(huán)去檢查某個變量的值,這其實(shí)是一 種很嚴(yán)重的錯誤)勤哗。如果是使用通知的方式薛闪,效率則很高,因?yàn)楫惒焦δ軒缀醪恍枰鲱~外的操作俺陋。至于回調(diào)函數(shù)豁延,其實(shí)和通知沒太多區(qū)別昙篙。
舉例:
#1. multiprocessing.Pool().apply_async() #發(fā)起異步調(diào)用后,
并不會等待任務(wù)結(jié)束才返回诱咏,相反苔可,會立即獲取一個臨時結(jié)果(并不是最終的結(jié)果,
可能是封裝好的一個對象)袋狞。
#2. concurrent.futures.ProcessPoolExecutor(3).submit(func,)
#3. concurrent.futures.ThreadPoolExecutor(3).submit(func,)
阻塞與非阻塞
阻塞
阻塞調(diào)用是指調(diào)用結(jié)果返回之前焚辅,當(dāng)前線程會被掛起(如遇到io操作)。調(diào)用線程只有在得到結(jié)果之后才會返回苟鸯。函數(shù)只有在得到結(jié)果之后才會將阻塞的線程激活同蜻。有人也許會把阻塞調(diào)用和同步調(diào)用等同起來,實(shí)際上他是不同的早处。對于同步調(diào)用來說湾蔓,很多時候當(dāng)前線程還是激活的,只是從邏輯上當(dāng)前函數(shù)沒有返回而已砌梆。
舉例:
1. 同步調(diào)用:apply一個累計1億次的任務(wù)默责,該調(diào)用會一直等待,直到任務(wù)返回結(jié)果為止咸包,
但并未阻塞滋倚颉(即便是被搶走cpu的執(zhí)行權(quán)限,那也是處于就緒態(tài));
2. 阻塞調(diào)用:當(dāng)socket工作在阻塞模式的時候烂瘫,如果沒有數(shù)據(jù)的情況下調(diào)用recv函數(shù)媒熊,
則當(dāng)前線程就會被掛起,直到有數(shù)據(jù)為止坟比。
非阻塞
非阻塞和阻塞的概念相對應(yīng)泛释,非阻塞調(diào)用指在不能立刻得到結(jié)果之前也會立刻返回,同時該函數(shù)不會阻塞當(dāng)前線程温算。
總結(jié)
- 同步與異步針對的是函數(shù)/任務(wù)的調(diào)用方式:同步就是當(dāng)一個進(jìn)程發(fā)起一個函數(shù)(任務(wù))調(diào)用的時候,一直等到函數(shù)(任務(wù))完成间影,而進(jìn)程繼續(xù)處于激活(非阻塞)狀態(tài)注竿。而異步情況下是當(dāng)一個進(jìn)程發(fā)起一個函數(shù)(任務(wù))調(diào)用的時候,不會等函數(shù)返回魂贬,而是繼續(xù)往下執(zhí)行巩割,當(dāng)函數(shù)返回的時候通過狀態(tài)、通知付燥、事件等方式通知進(jìn)程任務(wù)完成宣谈。
- 阻塞與非阻塞針對的是進(jìn)程或線程:阻塞是當(dāng)請求不能滿足的時候就將進(jìn)程掛起,而非阻塞則不會阻塞當(dāng)前進(jìn)程