go語言有哪些資料型別

2022-12-20 14:00:43

go語言的資料型別有:1、布林型,值只可以是常數true或false;2、數位型別,支援整型和浮點型數位,並且支援複數;3、字串型別,是一串固定長度的字元連線起來的字元序列;4、指標型別;5、陣列型別;6、結構化型別;7、Channel型別;8、函數型別;9、切片型別;10、介面型別;11、Map型別。

本教學操作環境:windows7系統、GO 1.18版本、Dell G3電腦。

Go 語言資料型別

在 Go 程式語言中,資料型別用於宣告函數和變數。

資料型別的出現是為了把資料分成所需記憶體大小不同的資料,程式設計的時候需要用巨量資料的時候才需要申請大記憶體,就可以充分利用記憶體。

Go 語言按類別有以下幾種資料型別:

序號型別和描述
1布林型
布林型的值只可以是常數 true 或者 false。一個簡單的例子:var b bool = true。
2數位型別
整型 int 和浮點型 float32、float64,Go 語言支援整型和浮點型數位,並且支援複數,其中位的運算採用二補數。
3字串型別:
字串就是一串固定長度的字元連線起來的字元序列。Go 的字串是由單個位元組連線起來的。Go 語言的字串的位元組使用 UTF-8 編碼標識 Unicode 文字。
4派生型別:
包括:
  • (a) 指標型別(Pointer)

  • (b) 陣列型別

  • (c) 結構化型別(struct)

  • (d) Channel 型別

  • (e) 函數型別

  • (f) 切片型別

  • (g) 介面型別(interface)

  • (h) Map 型別

Go語言中有豐富的資料型別,除了基本的整型、浮點型、布林型、字串外,還有陣列、切片、結構體、函數、map、通道(channel)等

1.整形

  • 整數

1.1.整型分為兩類

  • 按佔用的記憶體長度劃分
int8、int16、int32、int64
登入後複製
  • 按照是否有正負號劃分-無符號整型
uint8、uint16、uint32、uint64
登入後複製
  • 與 C 語言對比
uint8 對應 byte 型
int16 對應 C 語言中的 short 型
int64 對應 C 語言中的 long 型
登入後複製

1.2.整形描述

型別描述
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)

1.3.特殊整型

型別描述
int32位元作業系統上就是int32,64位元作業系統上就是int64
uint32位元作業系統上就是uint32,64位元作業系統上就是uint64
uintptr無符號整型,用於存放一個指標

1.4.注意

1.在使用 int 和 uint 型別時,不能假定它是 32 位或 64 位的整型,而是考慮 int 和 uint 可能在不同平臺上的差異
2.獲取物件的長度的內建 len() 函數返回的長度可以根據不同平臺的位元組長度進行變化
3.實際使用中,切片或 map 的元素數量等都可以用 int 來表示
4.在涉及到二進位制傳輸,讀寫檔案的結構描述時,為了保持檔案的結構不會受到不同編譯目標平臺位元組長度的影響,不要使用 int 和 uint
登入後複製

1.5.數位字面量語法

  • 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。
登入後複製
  • 可以藉助 fmt 函數來將一個整數以不同進位制形式展示
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,大寫字母顯示
}
登入後複製

2.浮點型

  • 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)
}
登入後複製

3.複數

  • complex64 和 complex128
  • 複數有實部和虛部,complex64 的實部和虛部為 32 位,complex128 的實部和虛部為 64 位
var c1 complex64
c1 = 1 + 2i
var c2 complex128
c2 = 2 + 3i
fmt.Println(c1)
fmt.Println(c2)
登入後複製

4.布林值

  • Go 語言中以 bool 型別進行宣告布林型資料
1.布林型資料只有 true 和 false 兩個值,布林型別變數的預設值為 false。
2.Go 語言中不允許將整型強制轉換為布林型.
3.布林型無法參與數值運算,也無法與其他型別進行轉換
登入後複製

5.字串

  • Go 語言中的字串以原生資料型別出現,使用字串就像使用其他原生資料型別(int、bool、float32、float64 等)一樣
  • Go 語言字串使用 UTF-8 編碼,可以在 Go 語言的原始碼中直接新增非 ASCII 碼字元

5.1.定義一個字串型別的變數

  • 使用 雙引號 定義 單行字串 變數

  • 使用 反引號 定義 多行字串 變數

  • 使用 單引號 定義 單個字元 變數

  • 範例演示

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)
}
登入後複製

5.2.字串跳脫

  • Go 語言的字串常見跳脫符包含回車、換行、單雙引號、製表符等
跳脫符含義
\r回車符 (返回行首)
\n換行符 (直接跳到下一行的同列位置)
\t製表符
'單引號
"雙引號
\反斜槓

5.3.字串跳脫-範例演示

package main

import (
    "fmt"
)

func main() {
    // 跳脫符的使用
    fmt.Println("\n# 跳脫符的使用 str := \"c:\\go\"")
}
登入後複製

5.4.字串操作

方法方法說明
len(str)求長度
+或fmt.Sprintf拼接字串
strings.Split分割
strings.contains判斷是否包含
strings.HasPrefix,strings.HasSuffix字首/字尾判斷
strings.Index(),strings.LastIndex()子串出現的位置
strings.Join(a[]string, sep string)join操作

5.5.字串操作-範例演示

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, " + "))
}
登入後複製

6.字元

6.1.定義一個字元變數

  • 組成字串的元素叫做 字元,使用單引號進行定義字元型別變數,字串使用雙引號定義
  • 可以通過遍歷或者單個獲取字串元素獲得字元
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)
}
登入後複製

6.2.字元型別有兩種

6.2.1.uint8-型別字元

  • go 語言中一般的英文數位字元使用 ASCII 碼的一個字元,佔據 8 位 bit 的記憶體空間,也就是常用的 byte 型

6.2.2.rune-型別字元

  • go 語言中處理中文日文或者其他複合字元時,需要用到 rune 型別,rune 型別實際是一個 int32,代表一個 UTF-8 字元(Unicode編碼)

7.字串拓展

7.1.字串遍歷-方法1-使用迴圈依次取出字串中的元素

// 字串遍歷-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()
-----------------------
登入後複製

7.2.字串遍歷-方法2-rune-型別遍歷可以使用 for range 迴圈

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 組成。
登入後複製

7.3.字串修改

  • 字串是固定值無法修改,如果要修改字串,需要先將其轉換成 []rune 或 []byte,完成後再轉換為 string 型別。無論哪種轉換,都會重新分配記憶體,並複製位元組陣列
func changeString() {
    s1 := "big"
    // 強制型別轉換
    byteS1 := []byte(s1)
    byteS1[0] = 'p'
    fmt.Println(string(byteS1))

    s2 := "白蘿蔔"
    runeS2 := []rune(s2)
    runeS2[0] = '紅'
    fmt.Println(string(runeS2))
}
登入後複製

8.型別轉換

  • Go語言中只有強制型別轉換,沒有隱式型別轉換。該語法只能在兩個型別之間支援相互轉換的時候使用

8.1.型別轉換-語法

T(表示式)
登入後複製
  • 其中,T 表示要轉換的型別,表示式包括變數、複雜運算元和函數返回值等

8.1.型別轉換-範例演示

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其它相關文章!