Go語言全棧開發:基本數據類型

Go語言中有豐富的數據類型,除了基本的整型、浮點型、布爾型、字符串外,還有數組、切片、結構體、函數、map、通道(channel)等。Go 語言的基本類型和其他語言大同小異。

基本數據類型

整型

整型分爲以下兩個大類: 按長度分爲:int8、int16、int32、int64 對應的無符號整型:uint8、uint16、uint32、uint64

其中,uint8就是我們熟知的byte型,int16對應C語言中的short型,int64對應C語言中的long型。
在這裏插入圖片描述
|特殊整型
在這裏插入圖片描述
注意: 在使用intuint類型時,不能假定它是32位或64位的整型,而是考慮intuint可能在不同平臺上的差異。

注意事項: 獲取對象的長度的內建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表示二進制
	fmt.Printf("%o \n", a) // 1010  佔位符%o表示八進制
	fmt.Printf("%x \n", a) // 1010  佔位符%x表示十六進制

	// 八進制  以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語言支持兩種浮點型數:float32float64。這兩種浮點型數據格式遵循IEEE 754標準: float32 的浮點數的最大範圍約爲 3.4e38,可以使用常量定義:math.MaxFloat32float64 的浮點數的最大範圍約爲 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(假)兩個值。

注意:

  1. 布爾類型變量的默認值爲false。
  2. Go 語言中不允許將整型強制轉換爲布爾型.
  3. 布爾型無法參與數值運算,也無法與其他類型進行轉換。
字符串

Go語言中的字符串以原生數據類型出現,使用字符串就像使用其他原生數據類型(int、bool、float32、float64 等)一樣。 Go 語言裏的字符串的內部實現使用UTF-8編碼。 字符串的值爲雙引號(")中的內容,可以在Go語言的源碼中直接添加非ASCII碼字符,例如:

s1 := "hello"
s2 := "你好"

|字符串轉義符

Go 語言的字符串常見轉義符包含回車、換行、單雙引號、製表符等,如下表所示。
在這裏插入圖片描述
舉個例子,我們要打印一個Windows平臺下的一個文件路徑:

package main
import (
    "fmt"
)
func main() {
    fmt.Println("str := \"c:\\Code\\lesson1\\go.exe\"")
}

|多行字符串

Go語言中要定義一個多行字符串時,就必須使用反引號字符:

s1 := `第一行
第二行
第三行
`
fmt.Println(s1)

反引號間換行將被作爲字符串中的換行,但是所有的轉義字符均無效,文本將會原樣輸出。

|字符串的常用操作
在這裏插入圖片描述

byte和rune類型

組成每個字符串的元素叫做“字符”,可以通過遍歷或者單個獲取字符串元素獲得字符。 字符用單引號(’)包裹起來,如:

var a := '中'
var b := 'x'

Go 語言的字符有以下兩種:

  1. uint8類型,或者叫 byte 型,代表了ASCII碼的一個字符。
  2. 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) 27494() 27721() 

因爲UTF8編碼下一個中文漢字由3~4個字節組成,所以我們不能簡單的按照字節去遍歷一個包含中文的字符串,否則就會出現上面輸出中第一行的結果。

字符串底層是一個byte數組,所以可以和[]byte類型相互轉換。字符串是不能修改的 字符串是由byte字節組成,所以字符串的長度是byte字節的長度。 rune類型用來表示utf8字符,一個rune字符由一個或多個byte組成。

|修改字符串

要修改字符串,需要先將其轉換成[]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))
}
類型轉換

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)
}

練習

  1. 編寫代碼分別定義一個整型、浮點型、布爾型、字符串型變量,使用fmt.Printf()搭配%T分別打印出上述變量的值和類型。
package main

import "fmt"

func main() {
	age := 18
	high := 1.80
	isMan := true
	name := "winstonfy"

	fmt.Printf("%v,%T \n", name, name)
	fmt.Printf("%v,%T \n", age, age)
	fmt.Printf("%v,%T \n", high, high)
	fmt.Printf("%v,%T \n", isMan, isMan)

}
  1. 編寫代碼統計出字符串"666武漢加油"中漢字的數量。
package main

import "unicode"

func main() {
   count := 0
   str1 := "666武漢加油"
   for _, char := range str1 {
   	if unicode.Is(unicode.Han, char) {
   		count++
   	}
   }
   println(count)
}

【對比python】
在這裏插入圖片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章