您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“GO語(yǔ)言的使用方法有哪些”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“GO語(yǔ)言的使用方法有哪些”吧!
Go語(yǔ)言很簡(jiǎn)單。并且每次你中途休息(cessation)之后回到代碼中時(shí),它沒(méi)有那么多詭異的錯(cuò)誤(quirk)來(lái)浪費(fèi)你的時(shí)間。再加上,它所需要的學(xué)習(xí)量很少,因?yàn)樗恼Z(yǔ)法比較大眾,開發(fā)者的學(xué)習(xí)曲線很平緩,這樣的特性本身就很吸引開發(fā)者。這也導(dǎo)致(facilitate)出現(xiàn)Bug的幾率很低。所以整個(gè)開發(fā)過(guò)程顯得如此簡(jiǎn)單快速。
一般來(lái)講,代碼量越多,項(xiàng)目越難維護(hù)。而一個(gè)區(qū)塊鏈系統(tǒng)需要的代碼可達(dá)幾千行,所以我們需要一門語(yǔ)言,來(lái)讓維護(hù)變得輕松。
我們初期有20位出色的工程師,大多來(lái)自JavaScript, Java, 和Python,也有的是系統(tǒng)工程師,善使C器。
我們自然需要同一個(gè)語(yǔ)言來(lái)協(xié)同工作。說(shuō)服(convince)他們來(lái)學(xué)習(xí)Go非常容易,但讓他們一個(gè)月速成Go語(yǔ)言工程師,卻也是挺簡(jiǎn)單。。。我倒不確定選擇其他語(yǔ)言是否也能有此神速。
不似Python, Go不是一種解釋型語(yǔ)言——它是編譯型的。這大大地(drastically)減少了在運(yùn)行中突然出現(xiàn)的Bug。這一點(diǎn)有點(diǎn)像C語(yǔ)言,代碼先被編譯,錯(cuò)誤會(huì)在編譯時(shí)出現(xiàn)并得到處理,然后才能運(yùn)行;但是,它比C更高級(jí),比JavaScript和Python更具生產(chǎn)力。
一個(gè)區(qū)塊鏈非常需要高效性,鑒于其使用的是加密(cryptographic)算法,鑒于它把大量數(shù)據(jù)傳輸(propagate)于網(wǎng)絡(luò),并存儲(chǔ)于網(wǎng)絡(luò)。
這一點(diǎn),在那些用Golang打造的工具和軟件中顯而易見。Docker,作為一種微服務(wù)的容器,也是用Golang打造。
我們已經(jīng)看到了我們能用Golang打造的微服務(wù)輕松駕馭百萬(wàn)數(shù)量的請(qǐng)求。
并發(fā)(Concurrency)是讓幾個(gè)程序或者一個(gè)程序的幾個(gè)部分同時(shí)間運(yùn)行,或者說(shuō)并行,以提升計(jì)算機(jī)的吞吐量(throughput)。通常,在Java或其他一些語(yǔ)言中,通過(guò)線程(threads)來(lái)實(shí)現(xiàn)并發(fā)。而Go則用的是“Goroutines”方法。Goroutines就是說(shuō)一些函數(shù),它們可以同另外的一些函數(shù)同時(shí)被執(zhí)行。一個(gè)Goroutine在內(nèi)存中占用大概4kb,而一個(gè)線程需要大約1024kb的內(nèi)存。所以,Goroutines同其他語(yǔ)言所使用的線程比起來(lái),小了250倍,這使得它也可以同時(shí)執(zhí)行不斷增加的其他Goroutines。
以下是Go語(yǔ)言在處理線程方面與Java的不同之處:
在Java中,對(duì)象(object)在工作單元間共享,其中某一單元為了訪問(wèn)到這個(gè)數(shù)據(jù),必須先得到它的對(duì)象鎖。在Golang中,工作單元間共享一種被稱為信道(channel)的東西,一個(gè)信道基本上就是一個(gè)先入先出通道(FIFO pipe)——工作單元可以向信道發(fā)起數(shù)據(jù)讀寫。
Go語(yǔ)言遵循著它的準(zhǔn)則——“不要通過(guò)內(nèi)存共享進(jìn)行通訊,應(yīng)當(dāng)通過(guò)通訊來(lái)共享內(nèi)存”(not to communicate by sharing memory, instead share memory by communicating)。
并行操作對(duì)于區(qū)塊鏈?zhǔn)怯兄厥庖饬x的。同時(shí)跑大量函數(shù)——這一巧妙而天然的特性使得Go程序靈活地運(yùn)行于分布式系統(tǒng),這正是區(qū)塊鏈的主要需求。不過(guò)這一特性早已被發(fā)掘,有Docker,MongoDB,Netflix,Uber等等等,他們的產(chǎn)品功能也都主要依賴于高并發(fā)。
很多基于穩(wěn)定區(qū)塊鏈的DApps和tools都是用的Go語(yǔ)言。你所需要的某個(gè)功能,很輕松就能找到一個(gè)相對(duì)應(yīng)的庫(kù)。
Go是編譯型的,所以直接由操作系統(tǒng)執(zhí)行。這讓我們可以更自如地實(shí)現(xiàn)像以太坊沙盒(EVM (Ethereum Virtual Machine))一樣的技術(shù)。而如果是Java,因?yàn)樗旧淼倪\(yùn)行載體JVM就是一個(gè)虛擬機(jī),要再在上面做一個(gè)沙盒,實(shí)質(zhì)是更高一層的抽象,這完全沒(méi)有必要,會(huì)浪費(fèi)計(jì)算機(jī)資源。
當(dāng)然,Go的使用體驗(yàn)像是腳本語(yǔ)言,學(xué)習(xí)成本很低,所以非常適合小型項(xiàng)目。而在QPS(The Queries per second)上,比起Java好太多,所以又適合用來(lái)構(gòu)建高請(qǐng)求量的服務(wù)。
一些美妙的Go代碼片段
1, 這個(gè)是輕易地從一個(gè)函數(shù)返回一個(gè)指針到局部變量:
2, 你可以在函數(shù)內(nèi)部再定義另外的函數(shù)并可以用函數(shù)作為返回值,其中的局部變量會(huì)被當(dāng)做閉包內(nèi)變量:
3, 基于對(duì)象編程:
到此,相信大家對(duì)“GO語(yǔ)言的使用方法有哪些”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。