1、數(shù)組是多個 相同類型 的數(shù)據(jù)的組合,一個數(shù)組一旦聲明/定義了,其 長度是固定的,不能動態(tài)變化 。
專注于為中小企業(yè)提供網(wǎng)站建設、做網(wǎng)站服務,電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)石龍免費做網(wǎng)站提供優(yōu)質的服務。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了近1000家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設實現(xiàn)規(guī)模擴充和轉變。
2、var arr []int? ? 這時arr就是一個slice 切片 。
3、數(shù)組中的元素可以是任何數(shù)據(jù)類型,包括值類型和引用類型,但是 不能混用 。
4、數(shù)組創(chuàng)建后,如果沒有賦值,有默認值如下:
? ? 數(shù)值類型數(shù)組:????默認值為 0
? ? 字符串數(shù)組:? ? ? ?默認值為 ""
? ? bool數(shù)組:? ? ? ? ? ?默認值為 false
5、使用數(shù)組的步驟:
? ? (1)聲明數(shù)組并開辟空間
? ? (3)給數(shù)組各個元素賦值
? ? (3)使用數(shù)組
6、數(shù)組的下標是從0開始的。
7、數(shù)組下標必須在指定范圍內(nèi)使用,否則報panic:數(shù)組越界,比如var arr [5]int的有效下標為0~4.
8、Go的數(shù)組屬于 值類型 ,在默認情況下是 值傳遞 ,因此會進行值拷貝。 數(shù)組間不會相互影響。
9、如想在其他函數(shù)中去修改原來的數(shù)組,可以使用 引用傳遞 (指針方式)。
10、長度是數(shù)組類型的一部分,在傳遞函數(shù)參數(shù)時,需要考慮數(shù)組的長度,看以下案例:
題1:編譯錯誤,因為不能把[3]int類型傳遞給[]int類型,前者是數(shù)組,后者是切片;
題2:編譯錯誤,因為不能把[3]int類型傳遞給[4]int類型;
題3:編譯正確,因為[3]int類型傳給[3]int類型合法。
本文介紹一些Go語言的基礎語法。
先來看一個簡單的go語言代碼:
go語言的注釋方法:
代碼執(zhí)行結果:
下面來進一步介紹go的基礎語法。
go語言中格式化輸出可以使用 fmt 和 log 這兩個標準庫,
常用方法:
示例代碼:
執(zhí)行結果:
更多格式化方法可以訪問中的fmt包。
log包實現(xiàn)了簡單的日志服務,也提供了一些格式化輸出的方法。
執(zhí)行結果:
下面來介紹一下go的數(shù)據(jù)類型
下表列出了go語言的數(shù)據(jù)類型:
int、float、bool、string、數(shù)組和struct屬于值類型,這些類型的變量直接指向存在內(nèi)存中的值;slice、map、chan、pointer等是引用類型,存儲的是一個地址,這個地址存儲最終的值。
常量是在程序編譯時就確定下來的值,程序運行時無法改變。
執(zhí)行結果:
執(zhí)行結果:
Go 語言的運算符主要包括算術運算符、關系運算符、邏輯運算符、位運算符、賦值運算符以及指針相關運算符。
算術運算符:
關系運算符:
邏輯運算符:
位運算符:
賦值運算符:
指針相關運算符:
下面介紹一下go語言中的if語句和switch語句。另外還有一種控制語句叫select語句,通常與通道聯(lián)用,這里不做介紹。
if語法格式如下:
if ... else :
else if:
示例代碼:
語法格式:
另外,添加 fallthrough 會強制執(zhí)行后面的 case 語句,不管下一條case語句是否為true。
示例代碼:
執(zhí)行結果:
下面介紹幾種循環(huán)語句:
執(zhí)行結果:
執(zhí)行結果:
也可以通過標記退出循環(huán):
--THE END--
數(shù)組是一個由 固定長度 的 特定類型元素 組成的序列,一個數(shù)組可以由零個或多個元素組成。 數(shù)組是值類型
數(shù)組的每個元素都可以通過索引下標來訪問,索引下標的范圍是從0開始到數(shù)組長度減1的位置,內(nèi)置函數(shù) len() 可以返回數(shù)組中元素的個數(shù)。
2.類型的打印,結果的第二種打印方式
3.對元素的修改或者賦值
4.判斷數(shù)組是否相等:長度、類型
4.數(shù)組的地址:連續(xù)存儲的空間
5.數(shù)組的賦值、地址、取值
6.數(shù)組的默認值
7.數(shù)組的初始化
8.數(shù)組的逆置
9.求數(shù)組的最大值、最小值、平均值
10.對數(shù)組字符串進行連接
11.冒泡排序法的實現(xiàn)
12.數(shù)組做函數(shù)的參數(shù)
13.二維數(shù)組:賦值和地址
14.二維數(shù)組:打印和輸出
15. 指針數(shù)組,每一個元素都是地址
17.數(shù)組的內(nèi)存分配
不是為了與眾不同。而是為了更加清晰易懂。
Rob Pike 曾經(jīng)在 Go 官方博客解釋過這個問題(原文地址:),簡略翻譯如下(水平有限翻譯的不對的地方見諒):
引言
Go語言新人常常會很疑惑為什么這門語言的聲明語法(declaration syntax)會和傳統(tǒng)的C家族語言不同。在這篇博文里,我們會進行一個比較,并做出解答。
C 的語法
首先,先看看 C 的語法。C 采用了一種聰明而不同尋常的聲明語法。聲明變量時,只需寫出一個帶有目標變量名的表達式,然后在表達式里指明該表達式本身的類型即可。比如:
int x;
上面的代碼聲明了 x 變量,并且其類型為 int——即,表達式 x 為 int 類型。一般而言,為了指明新變量的類型,我們得寫出一個表達式,其中含有我們要聲明的變量,這個表達式運算的結果值屬于某種基本類型,我們把這種基本類型寫到表達式的左邊。所以,下述聲明:
int *p;
int a[3];
指明了 p 是一個int類型的指針,因為 *p 的類型為 int。而 a 是一個 int 數(shù)組,因為 a[3] 的類型為 int(別管這里出現(xiàn)的索引值,它只是用于指明數(shù)組的長度)。
我們接下來看看函數(shù)聲明的情況。C 的函數(shù)聲明中關于參數(shù)的類型是寫在括號外的,像下面這樣:
int main(argc, argv)
int argc;
char *argv[];
{ /* ... */ }
如前所述,我們可以看到 main 之所以是函數(shù),是因為表達式 main(argc, argv) 返回 int。在現(xiàn)代記法中我們是這么寫的:
int main(int argc, char *argv[]) { /* ... */ }
盡管看起來有些不同,但是基本的結構是一樣的。
總的來看,當類型比較簡單時,C的語法顯得很聰明。但是遺憾的是一旦類型開始復雜,C的這套語法很快就能讓人迷糊了。著名的例子如函數(shù)指針,我們得按下面這樣來寫:
int (*fp)(int a, int b);
在這兒,fp 之所以是一個指針是因為如果你寫出 (*fp)(a, b) 這樣的表達式將會調(diào)用一個函數(shù),其返回 int 類型的值。如果當 fp 的某個參數(shù)本身又是一個函數(shù),情況會怎樣呢?
int (*fp)(int (*ff)(int x, int y), int b)
這讀起來可就點難了。
當然了,我們聲明函數(shù)時是可以不寫明參數(shù)的名稱的,因此 main 函數(shù)可以聲明為:
int main(int, char *[])
回想一下,之前 argv 是下面這樣的
char *argv[]
你有沒有發(fā)現(xiàn)你是從聲明的「中間」去掉變量名而后構造出其變量類型的?盡管這不是很明顯,但你聲明某個 char *[] 類型的變量的時候,竟然需要把名字插入到變量類型的中間。
我們再來看看,如果我們不命名 fp 的參數(shù)會怎樣:
int (*fp)(int (*)(int, int), int)
這東西難懂的地方可不僅僅是要記得參數(shù)名原本是放這中間的
int (*)(int, int)
它更讓人混淆的地方還在于甚至可能都搞不清這竟然是個函數(shù)指針聲明。我們接著看看,如果返回值也是個函數(shù)指針類型又會怎么樣
int (*(*fp)(int (*)(int, int), int))(int, int)
這已經(jīng)很難看出是關于 fp 的聲明了。
你自己還可以構建出比這更復雜的例子,但這已經(jīng)足以解釋 C 的聲明語法引入的某些復雜性了。
還有一點需要指出,由于類型語法和聲明語法是一樣的,要解析中間帶有類型的表達式可能會有些難度。這也就是為什么,C 在做類型轉換的時候總是要把類型用括號括起來的原因,像這樣
(int)M_PI
Go 的語法
非C家族的語言通常在聲明時使用一種不同的類型語法。一般是名字先出現(xiàn),然后常常跟著一個冒號。按照這樣來寫,我們上面所舉的例子就會變成下面這樣:
x: int
p: pointer to int
a: array[3] of int
這樣的聲明即便有些冗長,當至少是清晰的——你只需從左向右讀就行。Go 語言所采用的方案就是以此為基礎的,但為了追求簡潔性,Go 語言丟掉了冒號并去掉了部分關鍵詞,成了下面這樣:
x int
p *int
a [3]int
在 [3]int 和表達式中 a 的用法沒有直接的對應關系(我們在下一節(jié)會回過頭來探討指針的問題)。至此,你獲得了代碼清晰性方面的提升,但付出的代價是語法上需要區(qū)別對待。
下面我們來考慮函數(shù)的問題。雖然在 Go 語言里,main 函數(shù)實際上沒有參數(shù),但是我們先謄抄一下之前的 main 函數(shù)的聲明:
func main(argc int, argv *[]byte) int
粗略一看和 C 沒什么不同,不過自左向右讀的話還不錯。
main 函數(shù)接受一個 int 和一個指針并返回一個 int。
如果此時把參數(shù)名去掉,它還是很清楚——因為參數(shù)名總在類型的前面,所以不會引起混淆。
func main(int, *[]byte) int
這種自左向右風格的聲明的一個價值在于,當類型變得更復雜時,它依然相對簡單。下面是一個函數(shù)變量的聲明(相當于 C 語言里的函數(shù)指針)
f func(func(int,int) int, int) int
或者當它返回一個函數(shù)時:
f func(func(int,int) int, int) func(int, int) int
上面的聲明讀起來還是很清晰,自左向右,而且究竟哪一個變量名是當前被聲明的也容易看懂——因為變量名永遠在首位。
類型語法和表達式語法帶來的差別使得在 Go 語言里調(diào)用閉包也變得更簡單:
sum := func(a, b int) int { return a+b } (3, 4)
指針
指針有些例外。注意在數(shù)組 (array )和切片 (slice) 中,Go 的類型語法把方括號放在了類型的左邊,但是在表達式語法中卻又把方括號放到了右邊:
var a []int
x = a[1]
類似的,Go 的指針沿用了 C 的 * 記法,但是我們寫的時候也是聲明時 * 在變量名右邊,但在表達式中卻又得把 * 放到左左邊:
var p *int
x = *p
不能寫成下面這樣
var p *int
x = p*
因為后綴的 * 可能會和乘法運算混淆,也許我們可以改用 Pascal 的 ^ 標記,像這樣
var p ^int
x = p^
我們也許還真的應該把 * 像上面這樣改成 ^ (當然這么一改 xor 運算的符號也得改),因為在類型和表達式中的 * 前綴確實把好些事兒都搞得有點復雜,舉個例子來說,雖然我們可以像下面這樣寫
[]int("hi")
但在轉換時,如果類型是以 * 開頭的,就得加上括號:
(*int)(nil)
如果有一天我們愿意放棄用 * 作為指針語法的話,那么上面的括號就可以省略了。
可見,Go 的指針語法是和 C 相似的。但這種相似也意味著我們無法徹底避免在文法中有時為了避免類型和表達式的歧義需要補充括號的情況。
總而言之,盡管存在不足,但我們相信 Go 的類型語法要比 C 的容易懂。特別是當類型比較復雜時。