Go語言中有豐富的數(shù)據(jù)類型,除了基本的整型、浮點型、布爾型、字符串外,
還有數(shù)組、切片、結(jié)構(gòu)體、函數(shù)、map、通道(channel)等。
整型分為兩類:
按長度分為:int8、int16、int32、int64 -對應(yīng)的無符號整型:uint8、uint16、uint32、uint64
十多年的文圣網(wǎng)站建設(shè)經(jīng)驗,針對設(shè)計、前端、開發(fā)、售后、文案、推廣等六對一服務(wù),響應(yīng)快,48小時及時工作處理。營銷型網(wǎng)站的優(yōu)勢是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動調(diào)整文圣建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計,從而大程度地提升瀏覽體驗。創(chuàng)新互聯(lián)從事“文圣網(wǎng)站設(shè)計”,“文圣網(wǎng)站推廣”以來,每個客戶項目都認真落實執(zhí)行。
注意:
1.在使用int和uint類型時,不能假定它是32位或64位的整型,而是考慮int和uint可能在不同平臺上的差異。
2.通過len()獲取對象的長度,會根據(jù)不同平臺的字節(jié)長度進行變化。
3.實際使用中,切片或map的元素數(shù)量等可以使用int表示。
4.在涉及到二進制傳輸、讀寫文件的結(jié)構(gòu)描述時,為了保持文件的結(jié)構(gòu)不會受到不同編譯目標平臺字節(jié)長度的影響,不要使用int和uint。
Go1.13版本之后引入了數(shù)字字面兩語法,這樣便于開發(fā)者以二進制、八進制、或十六進制浮點數(shù)的格式定義數(shù)字。
例如:
v:=0b00101101,代表二進制的101101,相當于十進制的45。
v := 0o377,代表八進制的 377,相當于十進制的 255。
v := 0x1p-2,代表十六進制的 1 除以 22,也就是 0.25。
而且還允許我們用 _ 來分隔數(shù)字,比如: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語言支持兩種浮點型數(shù):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類型進行聲明布爾型數(shù)據(jù),布爾型數(shù)據(jù)只有true和false兩個值。
注意:
1.布爾類型變量的默認值是false。
2.GO語言中不允許將整型強制轉(zhuǎn)換為布爾型。
3.布爾型不能參與數(shù)值運算,也不能與其他類型進行轉(zhuǎn)換。
Go語言中的字符串,內(nèi)部編碼是UTF-8。字符串的值為雙引號中的內(nèi)容。
s1:="hello"
fmt.Println("str := \"c:\\Code\\lesson1\\go.exe\"")
結(jié)果:
str := "c:\Code\lesson1\go.exe"
GO語言中定義多行字符串,就必須使用`` 反引號字符
反引號間換行將被作為字符串中的換行。
所有的轉(zhuǎn)義字符無效,文本將會原樣輸出。
s1 :=`第一行
第二行
第三行
\n
\"
`
fmt.Println(s1)
結(jié)果:
第一行
第二行
第三行
\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字符。
當需要處理中文,日文或者其他復(fù)合字符時,則需要用到rune類型。rune類型實際是一個int32。
Go 使用了特殊的 rune 類型來處理 Unicode,讓基于 Unicode 的文本處理更為方便,也可以使用 byte 型進行默認字符串處理,性能和擴展性都有照顧。
package main
import "fmt"
func main() {
s1 := "hello他她它"
for i:=0;i
要修改字符串,需要先將其轉(zhuǎn)換成[]rune或[]byte,完成后在轉(zhuǎn)換為string。無論哪種轉(zhuǎn)換,都會重新分配內(nèi)存,并復(fù)制字節(jié)數(shù)組。
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語言中只有強制類型轉(zhuǎn)換,沒有隱式類型轉(zhuǎn)換。
強制類型轉(zhuǎn)換的語法:
T(表達式)
T表示要轉(zhuǎn)換的類型,表達式包活變量、復(fù)雜算子和函數(shù)返回值等。
該語法只能在兩個類型之間支持相互轉(zhuǎn)換的時候使用。
比如計算直角三角形的斜邊長時使用math包的Sqrt()函數(shù),該函數(shù)接收的是float64類型的參數(shù),而變量a和b都是int類型的,這個時候就需要將a和b強制類型轉(zhuǎn)換為float64類型。
func sqrtDemo() {
var a, b = 3, 4
var c int
// math.Sqrt()接收的參數(shù)是float64類型,需要強制轉(zhuǎn)換
c = int(math.Sqrt(float64(a*a + b*b)))
fmt.Println(c)
}