Go語言中有豐富的資料型別,除了基本的整型、浮點型、布爾型、字串外,還有陣列、切片、結構體、函式、map、通道(channel)等,Go 語言的基本型別和其他語言大同小異,
基本資料型別
整型
整型分為以下兩個大類: 按長度分為:int8、int16、int32、int64 對應的無符號整型:uint8、uint16、uint32、uint64
其中,uint8就是我們熟知的byte型,int16對應C語言中的short型,int64對應C語言中的long型,
| 型別 | 描述 |
|---|---|
| uint8 | 無符號 8位整型 (0 到 255) |
| uint16 | 無符號 16位整型 (0 到 65535) |
| uint32 | 無符號 32位整型 (0 到 4294967295) |
| uint64 | 無符號 64位整型 (0 到 18446744073709551615) |
| int8 | 有符號 8位整型 (-128 到 127) |
| int16 | 有符號 16位整型 (-32768 到 32767) |
| int32 | 有符號 32位整型 (-2147483648 到 2147483647) |
| int64 | 有符號 64位整型 (-9223372036854775808 到 9223372036854775807) |
特殊整型
| 型別 | 描述 |
|---|---|
| uint | 32位作業系統上就是uint32,64位作業系統上就是uint64 |
| int | 32位作業系統上就是int32,64位作業系統上就是int64 |
| uintptr | 無符號整型,用于存放一個指標 |
注意: 在使用int和 uint型別時,不能假定它是32位或64位的整型,而是考慮int和uint可能在不同平臺上的差異,
注意事項 獲取物件的長度的內建len()函式回傳的長度可以根據不同平臺的位元組長度進行變化,實際使用中,切片或 map 的元素數量等都可以用int來表示,在涉及到二進制傳輸、讀寫檔案的結構描述時,為了保持檔案的結構不會受到不同編譯目標平臺位元組長度的影響,不要使用int和 uint,
數字字面量語法(Number literals syntax)
Go1.13版本之后引入了數字字面量語法,這樣便于開發者以二進制、八進制或十六進制浮點數的格式定義數字,例如:
v := 0b00101101, 代表二進制的 101101,相當于十進制的 45, v := 0o377,代表八進制的 377,相當于十進制的 255, v := 0x1p-2,代表十六進制的 1 除以 2²,也就是 0.25, 而且還允許我們用 _ 來分隔數字,比如說:
v := 123_456 等于 123456,
我們可以借助fmt函式來將一個整數以不同進制形式展示,
package main
import "fmt"
func main(){
// 十進制
var a int = 10
fmt.Printf("%d \n", a) // 10
fmt.Printf("%b \n", a) // 1010 占位符%b表示二進制
// 八進制 以0開頭
var b int = 077
fmt.Printf("%o \n", b) // 77
// 十六進制 以0x開頭
var c int = 0xff
fmt.Printf("%x \n", c) // ff
fmt.Printf("%X \n", c) // FF
}
浮點型
Go語言支持兩種浮點型數:float32和float64,這兩種浮點型資料格式遵循IEEE 754標準: float32 的浮點數的最大范圍約為 3.4e38,可以使用常量定義:math.MaxFloat32, float64 的浮點數的最大范圍約為 1.8e308,可以使用一個常量定義:math.MaxFloat64,
列印浮點數時,可以使用fmt包配合動詞%f,代碼如下:
package main
import (
"fmt"
"math"
)
func main() {
fmt.Printf("%f\n", math.Pi)
fmt.Printf("%.2f\n", math.Pi)
}
復數
complex64和complex128
var c1 complex64 c1 = 1 + 2i var c2 complex128 c2 = 2 + 3i fmt.Println(c1) fmt.Println(c2)
復數有實部和虛部,complex64的實部和虛部為32位,complex128的實部和虛部為64位,
布林值
Go語言中以bool型別進行宣告布爾型資料,布爾型資料只有true(真)和false(假)兩個值,
注意:
- 布爾型別變數的默認值為
false, - Go 語言中不允許將整型強制轉換為布爾型.
- 布爾型無法參與數值運算,也無法與其他型別進行轉換,
字串
Go語言中的字串以原生資料型別出現,使用字串就像使用其他原生資料型別(int、bool、float32、float64 等)一樣, Go 語言里的字串的內部實作使用UTF-8編碼, 字串的值為雙引號(")中的內容,可以在Go語言的原始碼中直接添加非ASCII碼字符,例如:
s1 := "hello" s2 := "你好"
字串轉義符
Go 語言的字串常見轉義符包含回車、換行、單雙引號、制表符等,如下表所示,
| 轉義符 | 含義 |
|---|---|
\r |
回車符(回傳行首) |
\n |
換行符(直接跳到下一行的同列位置) |
\t |
制表符 |
\' |
單引號 |
\" |
雙引號 |
\\ |
反斜杠 |
舉個例子,我們要列印一個Windows平臺下的一個檔案路徑:
package main
import (
"fmt"
)
func main() {
fmt.Println("str := \"c:\\Code\\lesson1\\go.exe\"")
}
多行字串
Go語言中要定義一個多行字串時,就必須使用反引號字符:
s1 := `第一行 第二行 第三行 ` fmt.Println(s1)
反引號間換行將被作為字串中的換行,但是所有的轉義字符均無效,文本將會原樣輸出,
字串的常用操作
| 方法 | 介紹 |
|---|---|
| len(str) | 求長度 |
| +或fmt.Sprintf | 拼接字串 |
| strings.Split | 分割 |
| strings.contains | 判斷是否包含 |
| strings.HasPrefix,strings.HasSuffix | 前綴/后綴判斷 |
| strings.Index(),strings.LastIndex() | 子串出現的位置 |
| strings.Join(a[]string, sep string) | join操作 |
byte和rune型別
組成每個字串的元素叫做“字符”,可以通過遍歷或者單個獲取字串元素獲得字符, 字符用單引號(’)包裹起來,如:
var a := '中' var b := 'x'
Go 語言的字符有以下兩種:
uint8型別,或者叫 byte 型,代表了ASCII碼的一個字符,rune型別,代表一個UTF-8字符,
當需要處理中文、日文或者其他復合字符時,則需要用到rune型別,rune型別實際是一個int32,
Go 使用了特殊的 rune 型別來處理 Unicode,讓基于 Unicode 的文本處理更為方便,也可以使用 byte 型進行默認字串處理,性能和擴展性都有照顧,
// 遍歷字串
func traversalString() {
s := "hello沙河"
for i := 0; i < len(s); i++ { //byte
fmt.Printf("%v(%c) ", s[i], s[i])
}
fmt.Println()
for _, r := range s { //rune
fmt.Printf("%v(%c) ", r, r)
}
fmt.Println()
}
輸出:
104(h) 101(e) 108(l) 108(l) 111(o) 230(æ) 178(²) 153() 230(æ) 178(²) 179(³) 104(h) 101(e) 108(l) 108(l) 111(o) 27801(沙) 27827(河)
因為UTF8編碼下一個中文漢字由3~4個位元組組成,所以我們不能簡單的按照位元組去遍歷一個包含中文的字串,否則就會出現上面輸出中第一行的結果,
字串底層是一個byte陣列,所以可以和[]byte型別相互轉換,字串是不能修改的 字串是由byte位元組組成,所以字串的長度是byte位元組的長度, rune型別用來表示utf8字符,一個rune字符由一個或多個byte組成,
修改字串
func changeString() {
s1 := "big"
// 強制型別轉換
byteS1 := []byte(s1)
byteS1[0] = 'p'
fmt.Println(string(byteS1))
s2 := "白蘿卜"
runeS2 := []rune(s2)
runeS2[0] = '紅'
fmt.Println(string(runeS2))
}
要修改字串,需要先將其轉換成[]rune或[]byte,完成后再轉換為string,無論哪種轉換,都會重新分配記憶體,并復制位元組陣列,
型別轉換
Go語言中只有強制型別轉換,沒有隱式型別轉換,該語法只能在兩個型別之間支持相互轉換的時候使用,
強制型別轉換的基本語法如下:
T(運算式)
其中,T表示要轉換的型別,運算式包括變數、復雜算子和函式回傳值等.
比如計算直角三角形的斜邊長時使用math包的Sqrt()函式,該函式接收的是float64型別的引數,而變數a和b都是int型別的,這個時候就需要將a和b強制型別轉換為float64型別,
func sqrtDemo() {
var a, b = 3, 4
var c int
// math.Sqrt()接收的引數是float64型別,需要強制轉換
c = int(math.Sqrt(float64(a*a + b*b)))
fmt.Println(c)
}
練習題
- 撰寫代碼分別定義一個整型、浮點型、布爾型、字串型變數,使用
fmt.Printf()搭配%T分別列印出上述變數的值和型別, - 撰寫代碼統計出字串
"hello沙河小王子"中漢字的數量,
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/40843.html
標籤:Go
上一篇:Go語言基礎之運算子
下一篇:Go語言基礎之變數和常量
