1.3 Go语言基础之数据类型
Go語言中有豐富的數(shù)據(jù)類型,除了基本的整型、浮點型、布爾型、字符串外,還有數(shù)組、切片、結(jié)構(gòu)體、函數(shù)、map、通道(channel)等。Go 語言的基本類型和其他語言大同小異。
一、整型
1.1 基本類型
整型分為以下兩個大類: 按長度分為:int8(8位2進制數(shù))、int16、int32、int64 對應的無符號整型:uint8、uint16、uint32、uint64
其中,uint8就是我們熟知的byte型,int16對應C語言中的short型,int64對應C語言中的long型。
| uint8 | 無符號 8位整型 (0 到 255) |
| uint16 | 無符號 16位整型 (0 到 65535) |
| uint32 | 無符號 32位整型 (0 到 4294967295) |
| uint64 | 無符號 64位整型 (0 到 18446744073709551615) |
| int8 | 有符號 8位整型 (-128 到 127) |
| int16 | 有符號 16位整型 (-32768 到 32767) |
| int32 | 有符號 32位整型 (-2147483648 到 2147483647) |
| int64 | 有符號 64位整型 (-9223372036854775808 到 9223372036854775807) |
1.2 其他數(shù)字類型
| uint | 32位操作系統(tǒng)上就是uint32,64位操作系統(tǒng)上就是uint64 |
| int | 32位操作系統(tǒng)上就是int32(相當于內(nèi)存最大空間是2^32 大概就是4g),64位操作系統(tǒng)上就是int64 |
| uintptr | 無符號整型,用于存放一個指針 |
注意: 在使用int和 uint類型時,不能假定它是32位或64位的整型,而是考慮int和uint可能在不同平臺上的差異。
注意事項 獲取對象的長度的內(nèi)建len()函數(shù)返回的長度可以根據(jù)不同平臺的字節(jié)長度進行變化。實際使用中,切片或 map 的元素數(shù)量等都可以用int來表示。在涉及到二進制傳輸、讀寫文件的結(jié)構(gòu)描述時,為了保持文件的結(jié)構(gòu)不會受到不同編譯目標平臺字節(jié)長度的影響,不要使用int和 uint。
1.3 八進制&十六進制
package mainimport "fmt"func main(){// 十進制var a int = 10fmt.Printf("%d \n", a) // 10fmt.Printf("%b \n", a) // 1010 占位符%b表示二進制// 八進制 以0開頭var b int = 077fmt.Printf("%o \n", b) // 77// 十六進制 以0x開頭var c int = 0xfffmt.Printf("%x \n", c) // fffmt.Printf("%X \n", c) // FF// 變量的內(nèi)存地址fmt.Printf("%p \n", &a) // 0xc00004c080 占位符%p表示十六進制的內(nèi)存地址關(guān)于進制轉(zhuǎn)換之后會在(https://www.cnblogs.com/forever521Lee/p/10620859.html)
占位符總結(jié)(https://www.cnblogs.com/forever521Lee/p/10620865.html)
二、浮點型
Go語言支持兩種浮點型數(shù):float32和float64。這兩種浮點型數(shù)據(jù)格式遵循IEEE 754標準: float32 的浮點數(shù)的最大范圍約為 3.4e38,可以使用常量定義:math.MaxFloat32。 float64 的浮點數(shù)的最大范圍約為 1.8e308,可以使用一個常量定義:math.MaxFloat64。
打印浮點數(shù)時,可以使用fmt包配合動詞%f,代碼如下:
package main import ("fmt""math" ) func main() {fmt.Printf("%f\n", math.Pi)fmt.Printf("%.2f\n", math.Pi) //小數(shù)點后精確2位 }浮點數(shù)特別需要注意金融方面、p2p涉及到錢方面的浮點型操作時幾毛幾精確運算時,就如同下面(不精確)
兩種方式解決:
1、轉(zhuǎn)換成字符串,然后再去進行一個運算操作;
2、加入系統(tǒng)精確到分,那么我們就將其乘1000進行整數(shù)操作,這樣就可以避免出現(xiàn)錯誤
三、復數(shù)
complex64和complex128
var c1 complex64 c1 = 1 + 2i var c2 complex128 c2 = 2 + 3i fmt.Println(c1) fmt.Println(c2)復數(shù)有實部和虛部,complex64的實部和虛部為32位,complex128的實部和虛部為64位。
四、布爾值
Go語言中以bool類型進行聲明布爾型數(shù)據(jù),布爾型數(shù)據(jù)只有true(真)和false(假)兩個值。
注意:
五、字符串
Go語言中的字符串以原生數(shù)據(jù)類型出現(xiàn),使用字符串就像使用其他原生數(shù)據(jù)類型(int、bool、float32、float64 等)一樣。 Go 語言里的字符串的內(nèi)部實現(xiàn)使用UTF-8編碼。 字符串的值為雙引號(")中的內(nèi)容,可以在Go語言的源碼中直接添加非ASCII碼字符,例如:
s1 := "hello" s2 := "你好"5.1 字符串轉(zhuǎn)義符
Go 語言的字符串常見轉(zhuǎn)義符包含回車、換行、單雙引號、制表符等,如下表所示。
| \r | 回車符(返回行首) |
| \n | 換行符(直接跳到下一行的同列位置) |
| \t | 制表符 |
| ’ | 單引號 |
| ” | 雙引號 |
| \ | 反斜杠(在go語言中用于轉(zhuǎn)義) |
舉個例子:
package main import ("fmt" ) func main() {fmt.Println("str := \"c:\\Code\\lesson1\\go.exe\"") }5.2 多行字符串
Go語言中要定義一個多行字符串時,就必須使用反引號字符:
s1 := `第一行 第二行 第三行 ` fmt.Println(s1)反引號間換行將被作為字符串中的換行,但是所有的轉(zhuǎn)義字符均無效,文本將會原樣輸出。
5.3 字符串的常用操作
| len(str) | 求長度 |
| +或fmt.Sprintf | 拼接字符串 |
| strings.Split | 分割 |
| strings.contains | 判斷是否包含 |
| strings.HasPrefix,strings.HasSuffix | 前綴/后綴判斷 |
| strings.Index(),strings.LastIndex() | 子串出現(xiàn)的位置 |
| strings.Join(a[]string, sep string) | join操作 |
舉例
s1:= "hardenMVP"fmt.Println(len(s1))// 字符串拼接s2 := "houston"fmt.Println(s1+s2)s3 := fmt.Sprintf("%s----%s", s1, s2)fmt.Println(s3)// 分割ret := strings.Split(s1, "n")fmt.Println(ret)// 判斷是否包含ret2 := strings.Contains(s1, "MVP")fmt.Println(ret2)// 判斷前綴和后綴ret3 := strings.HasPrefix(s1, "har")ret4 := strings.HasSuffix(s1, "VP")fmt.Println(ret3, ret4)// 求子串的位置s4 := "applepen"fmt.Println(strings.Index(s4, "p"))fmt.Println(strings.LastIndex(s4, "p"))// joina1 := []string{"Python", "PHP", "JavaScript", "Ruby", "Golang"}fmt.Println(strings.Join(a1, "-"))5.4 byte和rune類型
組成每個字符串的元素叫做“字符”,可以通過遍歷或者單個獲取字符串元素獲得字符。 字符用單引號(’)包裹起來,如:
var a := '中' var b := 'x'Go 語言的字符有以下兩種: 1. uint8類型,或者叫 byte 型,代表了ASCII碼(能表示的最大位數(shù)是8位(2^8-1 也就是0-255)對于英文來說足夠用了)的一個字符。 2. rune類型(可以動態(tài)識別(識別到底是中文還是英文)),代表一個 UTF-8字符。
utf-8編碼下一個中文占3-4位(個字節(jié))
s1 := "Golang" c1 := 'G' // ASCII碼下占一個字節(jié)(8位 8bit(1bit就是01(二進制))) fmt.Println(s1, c1) s2 := "中國" c2 := '中' // UTF-8編碼下一個中文占3個字節(jié) fmt.Println(s2, c2)當需要處理中文、日文或者其他復合字符時,則需要用到rune類型。rune類型實際是一個int32。
Go 使用了特殊的 rune 類型來處理 Unicode,讓基于 Unicode 的文本處理更為方便,并且使用 byte 型進行默認字符串處理,性能和擴展性都有照顧。
// 遍歷字符串 func traversalString() {s := "hello沙河"for i := 0; i < len(s); i++ { //bytefmt.Printf("%v(%c) ", s[i], s[i]) //默認for循環(huán)按照ASCII碼去打印 %c表示輸出單個字符}fmt.Println()for _, r := range s { //rune for range 循環(huán) 是按照rune類型去遍歷的fmt.Printf("%v(%c) ", r, r) //for range循環(huán)后是按照utf8編碼打印}fmt.Println() }輸出:
104(h) 101(e) 108(l) 108(l) 111(o) 230(?) 178(2) 153() 230(?) 178(2) 179(3) 104(h) 101(e) 108(l) 108(l) 111(o) 27801(沙) 27827(河)注意:
1、遍歷中英文混合字符用for range循環(huán)
2、字符串底層是一個byte數(shù)組,所以可以和[]byte類型相互轉(zhuǎn)換。字符串是不能修改的 字符串是由byte字節(jié)組成,所以字符串的長度是byte字節(jié)的長度。 rune類型用來表示utf8字符,一個rune字符由一個或多個byte組成。
5.5 修改字符串
要修改字符串,需要先將其轉(zhuǎn)換成[]rune或[]byte,完成后再轉(zhuǎn)換為string。無論哪種轉(zhuǎn)換,都會重新分配內(nèi)存,并復制字節(jié)數(shù)組。
func changeString() {s1 := "big"// 強制類型轉(zhuǎn)換byteS1 := []byte(s1)byteS1[0] = 'p'fmt.Println(string(byteS1))s2 := "白蘿卜"runeS2 := []rune(s2)runeS2[0] = '紅'fmt.Println(string(runeS2)) }六、類型轉(zhuǎn)換
Go語言中只有強制類型轉(zhuǎn)換,沒有隱式類型轉(zhuǎn)換。 基本語法:
T(表達式)其中,T表示要轉(zhuǎn)換的類型。表達式包括變量、復雜算子和函數(shù)返回值等. 比如計算直角三角形的斜邊長。
例1:
func sqrtDemo() {var a, b = 3, 4var c int// math.Sqrt()接收的參數(shù)是float64類型,需要強制轉(zhuǎn)換c = int(math.Sqrt(float64(a*a + b*b)))fmt.Println(c) }例2:
// 強制類型轉(zhuǎn)換 s5 := "big" // 將字符串強制轉(zhuǎn)換成字節(jié)數(shù)組類型 byterArray := []byte(s5) fmt.Println(byterArray) byterArray[0] = 'p' fmt.Println(byterArray) // 將字節(jié)數(shù)組強制轉(zhuǎn)換成字符串類型 s5 = string(byterArray) fmt.Println(s5)轉(zhuǎn)載于:https://www.cnblogs.com/forever521Lee/p/10643489.html
總結(jié)
以上是生活随笔為你收集整理的1.3 Go语言基础之数据类型的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 还呗逾期一天有影响吗?逾期一天上征信吗?
- 下一篇: 教你简单理解分布式与传统单体架构的区别