golang最多支持多少線程 go是多線程還是協(xié)程?
go是多線程還是協(xié)程?3.1 concept在Go程序中,它由輕量級(jí)線程實(shí)現(xiàn),由Go運(yùn)行時(shí)管理。3.2與進(jìn)程和線程的區(qū)別1)進(jìn)程有自己的獨(dú)立堆棧,既不共享堆棧,也不共享堆棧。由操作系統(tǒng)安排。2)線程有
go是多線程還是協(xié)程?
3.1 concept
在Go程序中,它由輕量級(jí)線程實(shí)現(xiàn),由Go運(yùn)行時(shí)管理。
3.2與進(jìn)程和線程的區(qū)別
1)進(jìn)程有自己的獨(dú)立堆棧,既不共享堆棧,也不共享堆棧。由操作系統(tǒng)安排。
2)線程有自己的獨(dú)立堆棧和共享堆。共享堆和非共享堆由操作系統(tǒng)調(diào)度。
2)協(xié)同程序共享堆,但不共享堆棧。
3.3主線程與協(xié)程的關(guān)系
3.4協(xié)程輕于線程的原因
3.4.1線程的并發(fā)進(jìn)程
線程是內(nèi)核提供的服務(wù)。應(yīng)用程序通過(guò)系統(tǒng)調(diào)用使內(nèi)核啟動(dòng)線程,內(nèi)核負(fù)責(zé)線程調(diào)度和切換。當(dāng)線程正在等待I/O操作時(shí),當(dāng)線程變?yōu)椴豢擅麪顟B(tài)時(shí),將觸發(fā)上下文切換。現(xiàn)代操作系統(tǒng)一般采用搶占式調(diào)度。上下文切換通常發(fā)生在時(shí)鐘中斷和系統(tǒng)調(diào)用返回之前。調(diào)度器計(jì)算當(dāng)前線程的時(shí)間片。如果需要切換,則從隊(duì)列中選擇一個(gè)目標(biāo)線程,保存當(dāng)前線程的環(huán)境,并恢復(fù)目標(biāo)線程的運(yùn)行環(huán)境。最典型的方法是將ESP切換為指向目標(biāo)線程內(nèi)核堆堆棧,將EIP指向上次調(diào)度時(shí)目標(biāo)線程的指令地址。
3.4.2協(xié)程并發(fā)進(jìn)程
不依賴于操作系統(tǒng)及其提供的線程。golang自己實(shí)現(xiàn)的CSP并發(fā)模型:m,P,g
go corroutine也稱為用戶模式線程,在用戶模式下進(jìn)行corroutine之間的切換。在用戶模式下,沒有時(shí)鐘中斷、系統(tǒng)調(diào)用等機(jī)制,效率高。
3.5 go協(xié)程占用內(nèi)存較少的原因
執(zhí)行g(shù)o協(xié)程只需要很少的堆棧內(nèi)存(約4-5kb)。默認(rèn)情況下,線程堆棧大小為1MB。
goroutine是在堆上分配的一段代碼、一個(gè)函數(shù)項(xiàng)和一個(gè)堆棧。因此,我們可以輕松地創(chuàng)建數(shù)以萬(wàn)計(jì)的goroutine,但它們不是由操作系統(tǒng)調(diào)度的。
今年大三了,學(xué)了一年多的Java,可是都在說(shuō)go用的越來(lái)越多了,很多人都已經(jīng)轉(zhuǎn)go了,請(qǐng)問(wèn)我該怎么辦?
14年來(lái),有人說(shuō)Java將要消亡,那時(shí)Java仍然是中國(guó)的主流。17年來(lái),有人說(shuō)Java真的不行了,那時(shí)Java還是中國(guó)的主流。19年來(lái),有人說(shuō)Java不再好了,他們都在用python。然而,Java和C仍然是中國(guó)的主流。最后,在2020年,另一批不處于it地位的人說(shuō)Java已經(jīng)不好了,go和python是主流。你相信有一群培訓(xùn)機(jī)構(gòu)嗎???你知道java生態(tài)有多好嗎?你知道有多少java開發(fā)需要維護(hù)嗎?你知道一家公司突然改變技術(shù)方向要花多少錢嗎?
C語(yǔ)言中的goto語(yǔ)句。為什么老師反復(fù)強(qiáng)調(diào)不能用?
說(shuō)到goto的顏色變化,主要原因是goto太自由了,甚至比匯編語(yǔ)言跳躍還要自由。跳轉(zhuǎn)還需要考慮長(zhǎng)地址、短地址等跳轉(zhuǎn)。Goto完全沒有限制。它可以直接從函數(shù)內(nèi)部傳遞到函數(shù)外部,甚至傳遞到其他函數(shù)。這涉及到一個(gè)問(wèn)題。我們都知道函數(shù)調(diào)用是為了保護(hù)當(dāng)前的上下文,以及當(dāng)前的執(zhí)行堆棧和寄存器。一旦它進(jìn)入被調(diào)用函數(shù)的內(nèi)部,堆棧和寄存器都將改變。如果在函數(shù)內(nèi)部使用goto去其他地方而函數(shù)不返回,程序就會(huì)亂七八糟,導(dǎo)致內(nèi)存泄漏。因此,必須限制goto的使用。1函數(shù)內(nèi)部的goto只能轉(zhuǎn)到函數(shù),以確保函數(shù)可以返回到被調(diào)用的。2中斷中的goto也是一樣的。Goto必須能夠保證中斷正常返回,否則也會(huì)導(dǎo)致中斷異常。總之,不建議使用goto,因?yàn)樗梢蕴D(zhuǎn)到您想要執(zhí)行的位置,而不受任何限制。它太自由了,但這是好事還是壞事,取決于程序開發(fā)人員的設(shè)計(jì)是否考慮周全,是否會(huì)導(dǎo)致這樣那樣的問(wèn)題。