您好,登錄后才能下訂單哦!
Go語言中有豐富的數據類型,除了基本的整型、浮點型、布爾型、字符串外,
還有數組、切片、結構體、函數、map、通道(channel)等。
整型分為兩類:
按長度分為:int8、int16、int32、int64 -對應的無符號整型:uint8、uint16、uint32、uint64
注意:
1.在使用int和uint類型時,不能假定它是32位或64位的整型,而是考慮int和uint可能在不同平臺上的差異。
2.通過len()獲取對象的長度,會根據不同平臺的字節長度進行變化。
3.實際使用中,切片或map的元素數量等可以使用int表示。
4.在涉及到二進制傳輸、讀寫文件的結構描述時,為了保持文件的結構不會受到不同編譯目標平臺字節長度的影響,不要使用int和uint。
Go1.13版本之后引入了數字字面兩語法,這樣便于開發者以二進制、八進制、或十六進制浮點數的格式定義數字。
例如:
v:=0b00101101,代表二進制的101101,相當于十進制的45。
v := 0o377,代表八進制的 377,相當于十進制的 255。
v := 0x1p-2,代表十六進制的 1 除以 22,也就是 0.25。
而且還允許我們用 _ 來分隔數字,比如:v := 123_456 等于 123456。
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。
fmt.Printf("%f \n", math.Pi) //3.141593
fmt.Printf("%.2f \n", math.Pi) //3.14
var c1 complex64
c1 = 1 + 2i
var c2 complex128
c2 = 2 + 3i
fmt.Println(c1) //(1+2i)
fmt.Println(c2) //(2+3i)
GO語言中以bool類型進行聲明布爾型數據,布爾型數據只有true和false兩個值。
注意:
1.布爾類型變量的默認值是false。
2.GO語言中不允許將整型強制轉換為布爾型。
3.布爾型不能參與數值運算,也不能與其他類型進行轉換。
Go語言中的字符串,內部編碼是UTF-8。字符串的值為雙引號中的內容。
s1:="hello"
fmt.Println("str := \"c:\\Code\\lesson1\\go.exe\"")
結果:
str := "c:\Code\lesson1\go.exe"
GO語言中定義多行字符串,就必須使用`` 反引號字符
反引號間換行將被作為字符串中的換行。
所有的轉義字符無效,文本將會原樣輸出。
s1 :=`第一行
第二行
第三行
\n
\"
`
fmt.Println(s1)
結果:
第一行
第二行
第三行
\n
\"
package main
import (
"fmt"
"strings"
)
func main() {
s1 := "hello world"
fmt.Println(len(s1)) //11
fmt.Println(s1 + " ha") //hello world ha
splitStr :=strings.Split(s1, "l")
fmt.Printf("%#v----%T \n",splitStr,splitStr) //[]string{"he", "", "o wor", "d"}----[]string
fmt.Println(strings.Contains(s1,"l")) //true
fmt.Println(strings.HasPrefix(s1,"l")) //false
fmt.Println(strings.HasSuffix(s1,"l")) //false
fmt.Println(strings.Index(s1,"l")) //2
fmt.Println(strings.LastIndex(s1,"l")) //9
fmt.Println(strings.Join([]string{"he","llo"},"_")) //he_llo
}
組成每個字符串的元素叫做“字符”,可以遍歷或者單個獲取字符串元素獲得字符。字符用單引號(‘)包裹起來,如:
var a := 'x'
var b := 'y'
Go語言的字符有兩種:
1. uint8類型,或者叫byte型,代表了ASCII碼的一個字符。
2. rune類型,代表一個UTF-8字符。
當需要處理中文,日文或者其他復合字符時,則需要用到rune類型。rune類型實際是一個int32。
Go 使用了特殊的 rune 類型來處理 Unicode,讓基于 Unicode 的文本處理更為方便,也可以使用 byte 型進行默認字符串處理,性能和擴展性都有照顧。
package main
import "fmt"
func main() {
s1 := "hello他她它"
for i:=0;i<len(s1);i++{//byte
fmt.Printf("%v(%c)",s1[i],s1[i])
}
fmt.Println()
for _,r :=range s1{//rune
fmt.Printf("%v(%c)",r,r)
}
}
結果:
104(h)101(e)108(l)108(l)111(o)228(?)187(?)150()229(?)165(¥)185(1)229(?)174(?)131()
104(h)101(e)108(l)108(l)111(o)20182(他)22905(她)23427(它)
因為UTF8編碼下一個中文漢字由3~4個字節組成,所以我們不能簡單的按照字節去遍歷一個包含中文的字符串,否則就會出現上面輸出中第一行的結果。
字符串底層是一個byte數組,所以可以和[]byte類型相互轉換。
字符串是由byte字節組成,所以字符串的長度是byte字節的長度。
rune類型用來表示utf8字符,一個rune字符由一個或多個byte組成。
要修改字符串,需要先將其轉換成[]rune或[]byte,完成后在轉換為string。無論哪種轉換,都會重新分配內存,并復制字節數組。
package main
import "fmt"
func main() {
s1 := "hello他她它"
byteS1 := []byte(s1)
byteS1[0]='p'
byteS1[8]='p'
fmt.Println(string(byteS1)) //pello他p??它
s2 := "hello他她它"
byteS2 := []rune(s2)
byteS2[0]='p'
byteS2[5]='p'
byteS2[6]='我'
fmt.Println(string(byteS2)) //pellop我它
}
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)
}
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。