溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

go語言是不是后端語言

發(fā)布時間:2022-12-02 09:39:24 來源:億速云 閱讀:136 作者:iii 欄目:編程語言

今天小編給大家分享一下go語言是不是后端語言的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

go語言是后端語言。go語言是服務端的編程語言,其方向主要是后端。使用Go語言做后端開發(fā)的原因:1、在語言層面具有語法簡潔、執(zhí)行效率高(底層語言)的特點;2、Go語言是主打并發(fā)、為并發(fā)而生的,其出發(fā)點即是瞄準大數據+云計算時代背景下的高并發(fā)、分布式應用場景;3、Go語言可以在不同平臺直接編譯生成可執(zhí)行程序,基礎內存占用很少。

go語言是服務端的編程語言,go語言的方向不是前端,主要是后端。

Go(又稱 Golang)是谷歌開發(fā)的一種靜態(tài)強類型、編譯型、并發(fā)型,并具有垃圾回收功能的編程語言。Go于2009年11月正式宣布推出,成為開放源代碼項目,并在Linux及Mac平臺上進行了實現,后來追加了Windows系統(tǒng)下的實現。

Go 語言語法與 C 相近,但功能上有:內存安全,GC(垃圾回收),結構形態(tài)及 CSP-style 并發(fā)計算。

描述

Go的語法接近C語言,但對于變量的聲明有所不同。Go支持垃圾回收功能。Go的并行模型是以東尼·霍爾的通信順序進程(CSP)為基礎,采取類似模型的其他語言包括Occam和Limbo,但它也具有Pi運算的特征,比如通道傳輸。在1.8版本中開放插件(Plugin)的支持,這意味著現在能從Go中動態(tài)加載部分函數。

與C++相比,Go并不包括如枚舉、異常處理、繼承、泛型、斷言、虛函數等功能,但增加了 切片(Slice) 型、并發(fā)、管道、垃圾回收、接口(Interface)等特性的語言級支持。Go 2.0版本將支持泛型,對于斷言的存在,則持負面態(tài)度,同時也為自己不提供類型繼承來辯護。

不同于Java,Go內嵌了關聯數組(也稱為哈希表(Hashes)或字典(Dictionaries) ),就像字符串類型一樣

為什么使用Go語言做后端開發(fā)?

1、簡單高效:幾乎所有主流的編程語言如Java、C++、PHP、Python、JavaScript等等都是可以用于服務端開發(fā)的,Go語言作為后起之秀,在語言層面具有語法簡潔、執(zhí)行效率高(底層語言)的特點;相比之下,Java和Python、PHP都顯得低效,C++則太過麻煩,而Go則可以做到簡單與高效兼顧;

2、高并發(fā):Go語言是主打并發(fā)、為并發(fā)而生的,其出發(fā)點即是瞄準大數據+云計算時代背景下的高并發(fā)、分布式應用場景;

3、跨平臺:可以在不同平臺直接編譯生成可執(zhí)行程序,基礎內存占用很少,小應用占用幾M大型應用占用個幾十M就能很好運行,這使得golang可以在樹莓派之類的小設備上很好的運行,這一點表現比java要好的多;

容器化、分布式、微服務化是服務端發(fā)展的潮流,在這幾個方向上:

1、容器化:容器領域Go語言是絕對的霸主,大家所熟知的Docker和Kubernets(K8S)就是使用Go語言開發(fā)的;

2、分布式:最好的例證就是以太坊,因為區(qū)塊鏈即分布式賬本;

3、微服務:Go語言支持微服務的最好例證是今日頭條,今日頭條當前后端服務超過80%的流量是跑在 Go 構建的服務上。微服務數量超過100個,高峰 QPS 超過700萬,日處理請求量超過3000億,可能是業(yè)內最大規(guī)模的Go應用。

Go語言作為后端語言,跟其他后端語言相比,Go有什么優(yōu)勢或者特點呢?

  • 語言層面支持并發(fā),這個就是Go最大的特色,很容易編寫多線程程序,可以充分的利用多核。

  • 作為出生在21世紀的編程語言,支持垃圾回收,跟Java一樣不需要開發(fā)人員管理內存,可以專注于業(yè)務實現。

  • 豐富的標準庫,Go內置了大量的庫,特別是網絡庫非常強大。

  • Go 語言的部署比較簡單,直接編成機器碼,而且還有跨平臺的編譯的選項。

  • Go語言的理念是“少即是極多”,相對于C++,Java來說,Go語言更容易上手。

撰寫風格

在Go中有幾項規(guī)定,當不匹配以下規(guī)定時編譯將會產生錯誤。

  • 每行程序結束后不需要撰寫分號。

  • 左大括號不能夠換行放置。

  • if判斷式和for循環(huán)不需要以小括號包覆起來。

Go亦有內置gofmt工具,能夠自動整理代碼多余的空白、變量名稱對齊、并將對齊空格轉換成Tab?!鞠嚓P推薦:Go視頻教程】

編譯器

當前有兩個Go編譯器分支,分別為官方編譯器gc和gccgo。官方編譯器在初期使用C寫成,后用Go重寫從而實現自舉。Gccgo是一個使用標準GCC作為后端的Go編譯器。

官方編譯器支持跨平臺編譯(但不支持CGO),允許將源代碼編譯為可在目標系統(tǒng)、架構上執(zhí)行的二進制文件.

Go語言成功案例

1、Docker(容器)

到現在,Docker幾乎是Go再難找到也難以復制的一個成功案例。Docker項目在2014年9月份就拿到了C輪4000萬美元融資,版本迭代速度超快,目前從GitHub看到已有78個版本,而它僅僅是再2013年初才正式開始的一個項目而已。目前,國內Docker技術推廣也進行的如火如荼,比如 Docker中文社區(qū),CSDN也建立了 Docker專區(qū)。 Docker團隊之所以喜歡用Go語言,主要是Go具有強大的標準庫、全開發(fā)環(huán)境、跨平臺構建的能力。

2、Kubernetes(容器)

Kubernetes是2014年夏天Google推出的Kubernetes,基于Docker,其目的是讓用戶通過Kubernetes集群來進行云端容器集群的管理,而無需用戶進行復雜的設置工作。系統(tǒng)會自動選取合適的工作節(jié)點來執(zhí)行具體的容器集群調度處理工作。其核心概念是Container Pod(容器倉)。

3、Etcd & Fleet(分布式數據庫)

etcd是由CoreOS開發(fā)并維護鍵值存儲系統(tǒng),它使用Go語言編寫,并通過Raft一致性算法處理日志復制以保證強一致性。目前,Google的容器集群管理系統(tǒng)Kubernetes、開源PaaS平臺Cloud Foundry和CoreOS的Fleet都廣泛使用了etcd。 Fleet則是一個分布式的初始化系統(tǒng)。它們之所以選擇使用Go語言,則是因為Go語言對跨平臺的良好支持,以及其背后的強大社區(qū)。

4、Deis(云服務平臺)

Deis是一個基于Docker和CoreOS的開源PaaS平臺,旨在讓部屬和管理服務器上的應用變得輕松容易。它可以運行在AWS、GCE以及Openstack平臺下。

5、Flynn(云服務平臺)

Flynn是一個使用Go語言編寫的開源PaaS平臺,可自動構建部署任何應用到Docker容器集群上運行。Flynn項目受到Y Combinator的支持,目前仍在開發(fā)中,被稱為是下一代的開源PaaS平臺。

6、Lime(桌面應用)

相對上面的幾款Go語言在云端和服務器端之外,Lime則顯得比較特殊。Lime則是一款用Go語言寫的桌面編輯器程序,被看做是著名編輯器Sublime Text的開源實現。

7、Revel(Web框架)

Revel是一個高生產力的Go語言Web框架。Revel框架支持熱編譯,當編輯、保存和刷新源碼時,Revel會自動編譯代碼和模板;全棧特性,支持路由、參數解析、緩存、測試、國際化等功能。

8、InfluxDB(分布式數據庫)

一個Go語音編寫的開源分布式的時序、事件和指標數據庫,無需外部依賴。其設計目標是實現分布式和水平伸縮擴展。

9、.Syncthing(云盤)

一款用Go語言編寫的開源云存儲和同步服務工具,用戶的數據將由自己完全控制,所有的通信全都加密,每個訪問節(jié)點都用加密證書驗證。該項目被認為是Dropbox和 BitTorrent Sync的開源替代,Syncthing之所以選擇Go語言,也是出于跨平臺考慮。

10、Gogs(自助Git服務)

Gogs則是一款由國人無聞( GitHub)開發(fā)的自助Git服務項目。Gogs的目標是打造一個最簡單、最快速和最輕松的方式搭建自助Git服務。據作者稱,之所以選擇使用Go語言開發(fā),就是Go允許Gogs可以通過獨立的二進制分發(fā),且對跨平臺有良好支持。

以上就是“go語言是不是后端語言”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI