go語言的資料型別有:1、布林型,值只可以是常數true或false;2、數位型別,支援整型和浮點型數位,並且支援複數;3、字串型別,是一串固定長度的字元連線起來的字元序列;4、指標型別;5、陣列型別;6、結構化型別;7、Channel型別;8、函數型別;9、切片型別;10、介面型別;11、Map型別。
本教學操作環境:windows7系統、GO 1.18版本、Dell G3電腦。
在 Go 程式語言中,資料型別用於宣告函數和變數。
資料型別的出現是為了把資料分成所需記憶體大小不同的資料,程式設計的時候需要用巨量資料的時候才需要申請大記憶體,就可以充分利用記憶體。
Go 語言按類別有以下幾種資料型別:
序號 | 型別和描述 |
---|---|
1 | 布林型 布林型的值只可以是常數 true 或者 false。一個簡單的例子:var b bool = true。 |
2 | 數位型別 整型 int 和浮點型 float32、float64,Go 語言支援整型和浮點型數位,並且支援複數,其中位的運算採用二補數。 |
3 | 字串型別: 字串就是一串固定長度的字元連線起來的字元序列。Go 的字串是由單個位元組連線起來的。Go 語言的字串的位元組使用 UTF-8 編碼標識 Unicode 文字。 |
4 | 派生型別: 包括:
|
Go語言中有豐富的資料型別,除了基本的整型、浮點型、布林型、字串外,還有陣列、切片、結構體、函數、map、通道(channel)等
int8、int16、int32、int64
登入後複製
uint8、uint16、uint32、uint64
登入後複製
uint8 對應 byte 型
int16 對應 C 語言中的 short 型
int64 對應 C 語言中的 long 型
登入後複製
型別 | 描述 |
---|---|
int8 | 有符號 8位元整型 (-128 到 127) |
int16 | 有符號 16位元整型 (-32768 到 32767) |
int32 | 有符號 32位元整型 (-2147483648 到 2147483647) |
int64 | 有符號 64位元整型 (-9223372036854775808 到 9223372036854775807) |
uint8 | 無符號 8位元整型 (0 到 255) |
uint16 | 無符號 16位元整型 (0 到 65535) |
uint32 | 無符號 32位元整型 (0 到 4294967295) |
uint64 | 無符號 64位元整型 (0 到 18446744073709551615) |
型別 | 描述 |
---|---|
int | 32位元作業系統上就是int32,64位元作業系統上就是int64 |
uint | 32位元作業系統上就是uint32,64位元作業系統上就是uint64 |
uintptr | 無符號整型,用於存放一個指標 |
1.在使用 int 和 uint 型別時,不能假定它是 32 位或 64 位的整型,而是考慮 int 和 uint 可能在不同平臺上的差異
2.獲取物件的長度的內建 len() 函數返回的長度可以根據不同平臺的位元組長度進行變化
3.實際使用中,切片或 map 的元素數量等都可以用 int 來表示
4.在涉及到二進位制傳輸,讀寫檔案的結構描述時,為了保持檔案的結構不會受到不同編譯目標平臺位元組長度的影響,不要使用 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 表示 v 的值等於 123456。
登入後複製
package main
import "fmt"
func main() {
// 定義十進位制數
var a int = 10
fmt.Printf("%d \n", a) // 預留位置 %d 表示使用十進位制顯示為 10
fmt.Printf("%b \n", a) // 預留位置 %b 表示使用二進位制顯示為 1010
// 定義八進位制數,需要以 0 開頭
var b int = 077
fmt.Printf("%o \n", b) // 預留位置 %o 表示使用八進位制顯示為 77
// 定義十六進位制數,需要以 0x 開頭
var c int = 0xff
fmt.Printf("%x \n", c) // 預留位置 %x 表示使用十六進位制顯示為 ff,小寫字母顯示
fmt.Printf("%X \n", c) // 預留位置 %X 表示使用十六進位制顯示為 FF,大寫字母顯示
}
登入後複製
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)
}
登入後複製
var c1 complex64
c1 = 1 + 2i
var c2 complex128
c2 = 2 + 3i
fmt.Println(c1)
fmt.Println(c2)
登入後複製
1.布林型資料只有 true 和 false 兩個值,布林型別變數的預設值為 false。
2.Go 語言中不允許將整型強制轉換為布林型.
3.布林型無法參與數值運算,也無法與其他型別進行轉換
登入後複製
使用 雙引號 定義 單行字串 變數
使用 反引號 定義 多行字串 變數
使用 單引號 定義 單個字元 變數
範例演示
package main
import "fmt"
func main() {
// 使用 雙引號 定義 單行字串 變數
s1 := "hello" //定義英文字串
s2 := "你好" // 可以識別非 ASCII 碼,預設支援 utf-8 編碼
// 使用 反引號 定義 多行字串 變數
s3 := `
11111
22222 // 多行字串裡的雙斜槓也表示註釋
33333
`
// 使用 單引號 定義 單個字元 變數
s4 := 'h'
fmt.Println("\n單行字串01", s1)
fmt.Println("\n單行字串02", s2)
fmt.Println("\n多行字串", s3)
fmt.Println("\n字元定義", s4)
}
登入後複製
跳脫符 | 含義 |
---|---|
\r | 回車符 (返回行首) |
\n | 換行符 (直接跳到下一行的同列位置) |
\t | 製表符 |
' | 單引號 |
" | 雙引號 |
\ | 反斜槓 |
package main
import (
"fmt"
)
func main() {
// 跳脫符的使用
fmt.Println("\n# 跳脫符的使用 str := \"c:\\go\"")
}
登入後複製
方法 | 方法說明 |
---|---|
len(str) | 求長度 |
+或fmt.Sprintf | 拼接字串 |
strings.Split | 分割 |
strings.contains | 判斷是否包含 |
strings.HasPrefix,strings.HasSuffix | 字首/字尾判斷 |
strings.Index(),strings.LastIndex() | 子串出現的位置 |
strings.Join(a[]string, sep string) | join操作 |
package main
import (
"fmt"
"strings"
)
// 字串操作
func main() {
// 字串求長度
s3 := "zhongguojueqi"
fmt.Println("\n字串-求長度: ", len(s3))
// 字串拼接
s4 := "nihaoshijie"
fmt.Println("\n字串-拼接01: ", s3+s4)
s5 := fmt.Sprintf("%s---%s", s3, s4)
fmt.Println("\n字串-拼接02: ", s5)
// 字串分割
s6 := strings.Split(s3, "o")
fmt.Println("\n字串-分割: ", s6)
// 字串包含判斷
s7 := strings.Contains(s3, "o")
fmt.Println("\n字串-包含判斷01: ", s7)
fmt.Println("\n字串-包含判斷02: ", strings.Contains(s3, "o"))
// 字串字首, 字尾判斷
fmt.Println("\n字串-字首判斷: ", strings.HasPrefix(s3, "zhong"))
fmt.Println("\n字串-字尾判斷: ", strings.HasSuffix(s3, "qi"))
// 字串索引查詢
fmt.Println("\n字串-索引查詢-第一個字元 o 的索引: ", strings.Index(s3, "o"))
fmt.Println("\n字串-索引查詢-最後一個字元 o 的索引: ", strings.LastIndex(s3, "o"))
// 字串-join操作
s8 := []string{"aaa", "bbb", "ccc", "ddd"}
fmt.Println("\n字串-join 操作: ", strings.Join(s8, " + "))
}
登入後複製
func runeDemo01() { // 字元定義
a := '中' // 預設識別為 rune 型別的字元變數
b := "中" // 定義一個字串
var c byte = 'a' // 定義一個byte型別字元
var d rune = 'a' // 定義一個rune型別字元
fmt.Println(a, b)
fmt.Printf("%v,%T\n", c, c)
fmt.Printf("%v,%T\n", d, d)
}
登入後複製
// 字串遍歷-traversalString
package main
import (
"fmt"
)
func traversalString01() {
s := "hello世界"
for i := 0; i < len(s); i++ { // 中英文使用 for迴圈加 len() 方法遍歷迴圈,但遇到中文會有亂碼
fmt.Printf("%v(%c) ", s[i], s[i])
}
fmt.Println()
fmt.Println([]byte(s))
}
-----------------------
104(h) 101(e) 108(l) 108(l) 111(o) 228(ä) 184(¸) 150() 231(ç) 149() 140()
-----------------------
登入後複製
package main
import (
"fmt"
)
// 遍歷字串 traversalString
func traversalString02() {
s := "hello世界"
fmt.Println()
for _, r := range s { // 按照 rune 型別遍歷
fmt.Printf("%v(%c) ", r, r)
}
fmt.Println()
fmt.Println([]rune(s))
}
-----------------------
104(h) 101(e) 108(l) 108(l) 111(o) 19990(世) 30028(界)
-----------------------
登入後複製
1.因為 UTF8 編碼下一個中文漢字由 3~4 個位元組組成,所以我們不能簡單的按照位元組去遍歷一個包含中文的字串,否則就會出現上面輸出中第一行的結果
2.字串底層是一個 byte 陣列,所以可以和 []byte 型別相互轉換
3.字串是不能修改的 字串是由 byte 位元組組成,所以字串的長度是 byte 位元組的長度
4.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))
}
登入後複製
T(表示式)
登入後複製
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)
}
登入後複製
計算直角三角形的斜邊長時使用 math 包的 Sqrt() 函數,該函數接收的是 float64 型別的引數
而變數 a 和 b 都是 int 型別的,這個時候就需要將 a 和 b 強制型別轉換為 float64 型別
【相關推薦:Go視訊教學、】
以上就是go語言有哪些資料型別的詳細內容,更多請關注TW511.COM其它相關文章!