golang常用設(shè)計(jì)模式 Go語(yǔ)言現(xiàn)在的前景怎么樣?
Go語(yǔ)言現(xiàn)在的前景怎么樣?我學(xué)過(guò)爪哇和金剛。Java已經(jīng)使用了5年,我對(duì)Java的生態(tài)、工業(yè)語(yǔ)言和無(wú)數(shù)解決方案有著深刻的感受。無(wú)論是做互聯(lián)網(wǎng)的開(kāi)發(fā)還是做傳統(tǒng)行業(yè)的開(kāi)發(fā),java開(kāi)發(fā)總能解決很多問(wèn)題。國(guó)
Go語(yǔ)言現(xiàn)在的前景怎么樣?
我學(xué)過(guò)爪哇和金剛。Java已經(jīng)使用了5年,我對(duì)Java的生態(tài)、工業(yè)語(yǔ)言和無(wú)數(shù)解決方案有著深刻的感受。無(wú)論是做互聯(lián)網(wǎng)的開(kāi)發(fā)還是做傳統(tǒng)行業(yè)的開(kāi)發(fā),java開(kāi)發(fā)總能解決很多問(wèn)題。國(guó)內(nèi)巨頭阿里巴巴將java推向了極致。作為一種新的語(yǔ)音語(yǔ)言,golang簡(jiǎn)單的語(yǔ)法是前所未有的手難,他的生態(tài)也在慢慢開(kāi)始改善,比如docker etcd kubernetes Tidb、beego甚至阿里巴巴都在中國(guó)推出了Dubbo go。今天頭條、比力、滴滴等中國(guó)公司的技術(shù)堆棧已經(jīng)逐漸從Java變成了golang。不是Java不好,而是golang非常簡(jiǎn)單。如果您開(kāi)發(fā)一個(gè)包含20行代碼的web應(yīng)用程序,Java可能需要您了解完整的技術(shù)棧,比如spring引導(dǎo)棧,而golang只需要您了解httprouter。RPC框架的支持并不比Java好多少。去cicd領(lǐng)域完全是玩Java。畢竟,docker和kubernetes是由golang編寫(xiě)的,它們自然得到無(wú)縫支持。Golang的并發(fā)模型也領(lǐng)先于Java。Gorouting是為并發(fā)而生的,所以現(xiàn)在學(xué)習(xí)golang是一個(gè)很好的選擇,但是golang也有它自己的優(yōu)點(diǎn)它的缺點(diǎn)是項(xiàng)目管理和包依賴管理不如Java,通用支持也不是很好。與Java的生態(tài)相比,go的國(guó)內(nèi)生態(tài)還很欠缺。另外,爪哇的就業(yè)比哥朗簡(jiǎn)單,因?yàn)椴罹嗪艽?,但哥朗的就業(yè)工資并不低于爪哇。因此,從語(yǔ)言的角度看,golang優(yōu)于Java,生態(tài)上低于Java,理論上比Java有著光明的前景,這要看國(guó)內(nèi)的發(fā)展趨勢(shì),所以建議學(xué)習(xí)Go程序中的
3.1概念
,它是用輕量級(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ā)上下文切換?,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之間的切換。在用戶模式下,沒(méi)有時(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)度的。