概念:
公司主營業(yè)務:網(wǎng)站建設、成都網(wǎng)站制作、移動網(wǎng)站開發(fā)等業(yè)務。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。創(chuàng)新互聯(lián)是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)推出乳山免費做網(wǎng)站回饋大家。
Erlang是一個結(jié)構(gòu)化,動態(tài)類型編程語言,內(nèi)建并行計算支持。最初是由愛立信專門為通信應用設計的,比如控制交換機或者變換協(xié)議等,因此非常適 合于構(gòu)建分布式,實時軟并行計算系統(tǒng)。使用Erlang編寫出的應用運行時通常由成千上萬個輕量級進程組成,并通過消息傳遞相互通訊。
Go語言是一種編譯型語言,它結(jié)合了解釋型語言的游刃有余,動態(tài)類型語言的開發(fā)效率,以及靜態(tài)類型的安全性。它也打算成為現(xiàn)代的,支持網(wǎng)絡與多核計算的語言。要滿足這些目標,需要解決一些語言上的問題:一個富有表達能力但輕量級的類型系統(tǒng),并發(fā)與垃圾回收機制,嚴格的依賴規(guī)范等等。這些無法通過庫或工具解決好,因此Go也就應運而生了。
Erlang和golang的區(qū)別:
第一對鎖的態(tài)度不同,第二對異步IO的態(tài)度不同,第三消息機制不同。Erlang對鎖非常反感,認為變量不可變可以很大程度避免鎖。
Golang的觀點是鎖確實有很大的負擔,但是鎖基本上是無法避免的,一旦有人共享狀態(tài)并且互相搶占去改變他,這時候鎖是必須存在的。
Erlang服務器是單進程的,是邏輯上就沒有并發(fā)的東西,一個Process就是一個執(zhí)行體,所以Erlang的服務器和golang的服務器不一樣,golang的服務器是多進程的(goroutine)一起構(gòu)成的一個服務器。每個請求建立一個獨立的進程(goroutine)。
但是Erlang不同,一個服務器就是一個單進程的,所有的并發(fā)請求都進入到了進程郵箱,然后這個服務器從進程郵箱里取郵件(請求的內(nèi)容)處理,Erlang的服務器并沒有并發(fā)的請求,所以不需要所鎖。
Erlang的高并發(fā)實現(xiàn):
第一:每個Erlang的物理進會有很多的服務器,每個服務器是互相無干擾的,他們可以并發(fā)。
第二是單服務器高并發(fā)使用的是異步IO。
go認為何時都不應該有異步IO的代碼,Erlang則是在異步IO的基礎上加上輕量級進程模型的混雜。
Golang對并發(fā)的支持:
第一:價值回歸,golang最重要的事情是讓執(zhí)行成本降低,golang的棧最小可以到4K。
第二:把執(zhí)行體作為語言內(nèi)建的標準設施(golang的代碼風格只有標準化得一種)。go得并發(fā)模型是最古老的并發(fā)模型,該并發(fā)模型包括,routine,原子操作,互斥體,同步,消息,同步IO。
以上就是erlang和golang的區(qū)別的詳細內(nèi)容,更多請關(guān)注創(chuàng)新互聯(lián)其它相關(guān)文章!
文章標題:golang與erlang的區(qū)別是什么
鏈接分享:http://chinadenli.net/article2/ihpsoc.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供域名注冊、營銷型網(wǎng)站建設、品牌網(wǎng)站設計、網(wǎng)站建設、做網(wǎng)站、網(wǎng)站排名
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)