為什么golang的開發(fā)效率高看
沈丘網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)!從網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、自適應(yīng)網(wǎng)站建設(shè)等網(wǎng)站項(xiàng)目制作,到程序開發(fā),運(yùn)營維護(hù)。創(chuàng)新互聯(lián)成立于2013年到現(xiàn)在10年的時(shí)間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)。
golang是一編譯型的強(qiáng)類型語言,它在開發(fā)上的高效率主要來自于后發(fā)優(yōu)勢,不用考慮舊有惡心的歷史,又有一個(gè)較高的工程視角。良好的避免了程序員因?yàn)槎?{ 需不需要獨(dú)占一行 地這種革命問題打架,也解決了一部分趁編譯時(shí)間找產(chǎn)品妹妹搭訕的階級敵人。
它有自己的包管理機(jī)制,工具鏈成熟,從開發(fā)、調(diào)試到發(fā)布都很簡單方便;
有反向接口、defer、coroutine等大量的syntactic sugar;
編譯速度快,因?yàn)槭菑?qiáng)類型語言又有g(shù)c,只要通過編譯,非業(yè)務(wù)毛病就很少了;
它在語法級別上支持了goroutine,這是大家說到最多的內(nèi)容,這里重點(diǎn)提一下。首先,coroutine并不稀罕,語言并不能超越硬件、操作系統(tǒng)實(shí)現(xiàn)神乎其神的功能。golang可以做到事情,其他語言也可以做到,譬如c++,在boost庫里面自己就有的coroutine實(shí)現(xiàn)(當(dāng)然用起來跟其他boost庫一樣惡心)。golang做的事情,是把這一套東西的使用過程簡化了,并且提供了一套channel的通信模式,使得程序員可以忽略諸如死鎖等問題。
goroutine的目的是描述并發(fā)編程模型。并發(fā)與并行不同,它并不需要多核的硬件支持,它不是一種物理運(yùn)行狀態(tài),而是一種程序邏輯流程。它的主要目的不是利用多核提高運(yùn)行效率,而是提供一種更容易理解、不容易出錯(cuò)的語言來描述問題。
實(shí)際上golang默認(rèn)就是運(yùn)行在單OS進(jìn)程上面的,通過指定環(huán)境變量GOMAXPROCS才能轉(zhuǎn)身跑在多OS進(jìn)程上面。有人提到了的pomelo,開源本來是一件很不錯(cuò)的事情,但是基于自己對callback hell的偏見,我一直持有這種態(tài)度:敢用nodejs寫大規(guī)模游戲服務(wù)器的人,都是真正的勇士 : ) 。
2、Erlang與Golang的coroutine有啥區(qū)別,coroutine是啥看
coroutine本質(zhì)上是語言開發(fā)者自己實(shí)現(xiàn)的、處于user space內(nèi)的線程,無論是erlang、還是golang都是這樣。需要解決沒有時(shí)鐘中斷;碰著阻塞式i\o,整個(gè)進(jìn)程都會被操作系統(tǒng)主動掛起;需要自己擁有調(diào)度控制能力(放在并行環(huán)境下面還是挺麻煩的一件事)等等問題。那為啥要廢老大的勁自己做一套線程放user space里面呢看
并發(fā)是服務(wù)器語言必須要解決的問題;
system space的進(jìn)程還有線程調(diào)度都太慢了、占用的空間也太大了。
把線程放到user space的可以避免了陷入system call進(jìn)行上下文切換以及高速緩沖更新,線程本身以及切換等操作可以做得非常的輕量。這也就是golang這類語言反復(fù)提及的超高并發(fā)能力,分分鐘給你開上幾千個(gè)線程不費(fèi)力。
不同的是,golang的并發(fā)調(diào)度在i/o等易發(fā)阻塞的時(shí)候才會發(fā)生,一般是內(nèi)封在庫函數(shù)內(nèi);erlang則更夸張,對每個(gè)coroutine維持一個(gè)計(jì)數(shù)器,常用語句都會導(dǎo)致這個(gè)計(jì)數(shù)器進(jìn)行reduction,一旦到點(diǎn),立即切換調(diào)度函數(shù)。
中斷介入程度的不同,導(dǎo)致erlang看上去擁有了preemptive scheduling的能力,而golang則是cooperative shceduling的。golang一旦寫出純計(jì)算死循環(huán),進(jìn)程內(nèi)所有會話必死無疑;要有大計(jì)算量少i\o的函數(shù)還得自己主動叫runtime.Sched()來進(jìn)行調(diào)度切換。
3、golang的運(yùn)行效率怎么樣看
我是相當(dāng)反感所謂的ping\pong式benchmark,運(yùn)行效率需要放到具體的工作環(huán)境下面考慮。
首先,它再快也是快不過c的,畢竟底下做了那么多工作,又有調(diào)度,又有g(shù)c什么的。那為什么在那些benchmark里面,golang、nodejs、erlang的響應(yīng)效率看上去那么優(yōu)秀呢,響應(yīng)快,并發(fā)強(qiáng)看并發(fā)能力強(qiáng)的原因上面已經(jīng)提到了,響應(yīng)快是因?yàn)榇罅糠亲枞絠\o操作出現(xiàn)的原因。這一點(diǎn)c也可以做到,并且能力更強(qiáng),但是得多寫不少優(yōu)質(zhì)代碼。
然后,針對游戲服務(wù)器這種高實(shí)時(shí)性的運(yùn)行環(huán)境,GC所造成的跳幀問題確實(shí)比較麻煩,前面的大神 @達(dá)達(dá) 有比較詳細(xì)的論述和緩解方案,就不累述了 。隨著golang的持續(xù)開發(fā),相信應(yīng)該會有非常大的改進(jìn)。一是屏蔽內(nèi)存操作是現(xiàn)代語言的大勢所趨,它肯定是需要被實(shí)現(xiàn)的;二是GC算法已經(jīng)相當(dāng)?shù)某墒?,效率勉勉?qiáng)強(qiáng)過得去;三是可以通過incremental的操作來均攤cpu消耗。
用這一點(diǎn)點(diǎn)效率損失換取一個(gè)更高的生產(chǎn)能力是不是值得呢看我覺得是值得的,硬件已經(jīng)很便宜了,人生苦短,讓自己的生活更輕松一點(diǎn)吧: )。
4、基于以上的論述,我認(rèn)為采用go進(jìn)行小范圍的MMORPG開發(fā)是可行的。
Go和java產(chǎn)生的背景和語言的定義不一樣,比較他們的好壞沒多大意義,適合就是最好的,當(dāng)你去做一個(gè)大型的項(xiàng)目的時(shí)候,使用java能夠更清晰地展示出你的業(yè)務(wù)。自身提供了比較完善的庫。
Go語言也有面向函數(shù)和面向?qū)ο蟮淖兂煞桨?,其自身的性能決定了go語言更適合做中間件,底層的各種框架。
語言對企業(yè)來說,是制造生產(chǎn)力的,哪種語言能夠給我們帶來更好的收益,我們才選擇它們。
Revel Web開源框架
個(gè)高效的Go語言Web開發(fā)框架,?其思路完全來自 Java 的?Play Framework。
特點(diǎn)
熱編譯,簡單可選,同步(每個(gè)請求都創(chuàng)建自己的goroutine來處理。
Go語言Web框架:beego
一個(gè)用Go開發(fā)的應(yīng)用框架,思路來自于tornado,路由設(shè)計(jì)來源于sinatra。
支持特性
MVC;
REST;
智能路由;
日志調(diào)試;
配置管理;
模板自動渲染;
layout設(shè)計(jì);
中間件插入邏輯;
方便的JSON/XML服務(wù);
Go作為近兩年迅速流行起來的編程語言始終致力于使事情簡單化。它并未引入很多新概念,而是聚焦于打造一門簡單的語言,讓開發(fā)者使用起來感覺異??焖偾液唵?。相信有意向深入學(xué)習(xí)Go語言的小伙伴都在研究Go的開源項(xiàng)目,今天我就把自己覺得不錯(cuò)的6個(gè)Go開源項(xiàng)目推薦給大家,希望大家能獲得收獲和成長。
推薦一:kubernetes 【Star:44418】
Kubernetes基于Docker,其目的是讓用戶通過Kubernetes集群來進(jìn)行云端容器集群的管理,而無需用戶進(jìn)行復(fù)雜的設(shè)置工作。系統(tǒng)會自動選取合適的工作節(jié)點(diǎn)來執(zhí)行具體的容器集群調(diào)度處理工作。
推薦二:etcd 【Star:21408】
etcd是由CoreOS開發(fā)并維護(hù)鍵值存儲系統(tǒng),它使用Go語言編寫,并通過Raft一致性算法處理日志復(fù)制以保證強(qiáng)一致性。目前,Google的容器集群管理系統(tǒng)Kubernetes、開源PaaS平臺Cloud Foundry和CoreOS的Fleet都廣泛使用了etcd。
推薦三:deis 【Star:6093】
Deis是一個(gè)基于Docker和CoreOS的開源PaaS平臺,旨在讓部屬和管理服務(wù)器上的應(yīng)用變得輕松容易。它可以運(yùn)行在AWS、GCE以及Openstack平臺下。
推薦四:flynn 【Star:6936】
Flynn是一個(gè)使用Go語言編寫的開源PaaS平臺,可自動構(gòu)建部署任何應(yīng)用到Docker容器集群上運(yùn)行。Flynn項(xiàng)目受到Y(jié) Combinator的支持,目前仍在開發(fā)中,被稱為是下一代的開源PaaS平臺。
推薦五:lime 【Star:13775】
相對上面的幾款Go語言在云端和服務(wù)器端之外,Lime則顯得比較特殊。Lime,則是一款用Go語言寫的桌面編輯器程序,被看做是著名編輯器Sublime Text的開源實(shí)現(xiàn)。
六:revel 【Star:10508】
Revel是一個(gè)高生產(chǎn)力的Go語言Web框架。Revel框架支持熱編譯,當(dāng)編輯、保存和刷新源碼時(shí),Revel會自動編譯代碼和模板;全棧特性,支持路由、參數(shù)解析、緩存、測試、國際化等功能。
分享標(biāo)題:go語言框架對比,go語言框架使用情況對比
本文URL:http://sd-ha.com/article28/dssipcp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)網(wǎng)站建設(shè)、自適應(yīng)網(wǎng)站、企業(yè)建站、網(wǎng)站建設(shè)、外貿(mào)建站、商城網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)