uint8
就是咱們熟知的byte
型類型 | 描述 |
---|---|
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) |
特殊整型golang
類型 | 描述 |
---|---|
uint | 32位操做系統上就是uint32 ,64位操做系統上就是uint64 |
int | 32位操做系統上就是int32 ,64位操做系統上就是int64 |
uintptr | 無符號整型,用於存放一個指針 |
在使用int
和 uint
類型時,不能假定它是32位或64位的整型,而是考慮int
和uint
可能在不一樣平臺上的差別數組
注意事項 獲取對象的長度的內建len()
函數返回的長度能夠根據不一樣平臺的字節長度進行變化。實際使用中,切片或 map 的元素數量等均可以用int
來表示。在涉及到二進制傳輸、讀寫文件的結構描述時,爲了保持文件的結構不會受到不一樣編譯目標平臺字節長度的影響,不要使用int
和 uint
安全
Go語言支持兩種浮點型數:float32
和float64
函數
打印浮點數時,可使用fmt
包配合動詞%f
ui
package main import ( "fmt" "math" ) func main() { fmt.Printf("%f\n", math.Pi) fmt.Printf("%.2f\n", math.Pi) }
Go語言中以bool
類型進行聲明布爾型數據編碼
注意:操作系統
false
。Go語言中的字符串以原生數據類型出現,使用字符串就像使用其餘原生數據類型(int、bool、float3二、float64 等)同樣。 Go 語言裏的字符串的內部實現使用UTF-8
編碼。 字符串的值爲雙引號(")
中的內容,能夠在Go語言的源碼中直接添加非ASCII碼字符指針
t1 := "hello" t2 := "世界"
轉義符 | 含義 |
---|---|
\r |
回車符(返回行首) |
\n |
換行符(直接跳到下一行的同列位置) |
\t |
製表符 |
\' |
單引號 |
\" |
雙引號 |
\\ |
反斜槓 |
t1 := `第一行 第二行 好多行 ` fmt.Println(t1)
反引號間換行將被做爲字符串中的換行,可是全部的轉義字符均無效,文本將會原樣輸出code
方法 | 介紹 |
---|---|
len(str) | 求長度 |
+或fmt.Sprintf | 拼接字符串 |
strings.Split | 分割 |
strings.contains | 判斷是否包含 |
strings.HasPrefix,strings.HasSuffix | 前綴/後綴判斷 |
strings.Index(),strings.LastIndex() | 子串出現的位置 |
strings.Join(a[]string, sep string) | join操做 |
type Human struct { Name string } var people = Human{Name:"zhangsan"}
佔位符 | 說明 | 事例 | 輸出 |
---|---|---|---|
%v | 相應值的默認格式 | Printf("%v", people) | {zhangsan} |
%+v | 打印結構體時,會添加字段名 | Printf("%+v",people) | {Name:zhangsan} |
%#v | 相應值的Go語法表示 | Printf("%#v", people) | main.Human{Name:"zhangsan"} |
%T | 相應值的類型的Go語法表示 | Printf("%T", people) | main.Human |
%% | 字面上的百分號,並不是值的佔位符 | Printf("%%") | % |
%t | true 或 false | Printf("%t", true) | true |
%b | 二進制表示 | Printf("%b", 5) | 101 |
%c | 相應Unicode碼點所表示的字符 | Printf("%c", 0x4E2D) | 中 |
%d | 十進制表示 | Printf("%d", 0x12) | 18 |
%o | 八進制表示 | Printf("%d", 10) | 12 |
%q | 單引號圍繞的字符字面值,由Go語法安全地轉義 | Printf("%q", 0x4E2D) | '中' |
%x | 十六進制表示,字母形式爲小寫 a-f | Printf("%x", 13) | d |
%X | 十六進制表示,字母形式爲大寫 A-F | Printf("%x", 13) | D |
%U | Unicode格式:U+1234,等同於 "U+%04X" | Printf("%U", 0x4E2D) | U+4E2D |
%f | 有小數點而無指數,例如 123.456 | Printf("%f", 10.2) | 10.200000 |
%g | 根據狀況選擇 %e 或 %f 以產生更緊湊的(無末尾的0)輸出 | Printf("%g", 10.20) | 10.2 |
%s | 輸出字符串表示(string類型或[]byte) | Printf("%s",[]byte("Go語言")) | Go語言 |
%q | 雙引號圍繞的字符串,由Go語法安全地轉義 | Printf("%q", "Go語言") | "Go語言" |
%x | 十六進制,小寫字母,每字節兩個字符 | Printf("%x", "golang") | 676f6c616e67 |
%X | 十六進制,大寫字母,每字節兩個字符 | Printf("%X", "golang") | 676F6C616E67 |
%p | 十六進制表示,前綴 0x | Printf("%p", &people) | 0x4f57f0 |
組成每一個字符串的元素叫作「字符」,能夠經過遍歷或者單個獲取字符串元素得到字符。 字符用單引號(’)包裹起來對象
var a := 'h' var b := '世'
Go 語言的字符有如下兩種:
uint8
類型,或者叫 byte 型,表明了ASCII碼
的一個字符。rune
類型,表明一個 UTF-8字符
。當須要處理中文則須要用到rune
類型。rune
類型實際是一個int32
。
Go 使用了特殊的 rune 類型來處理 Unicode,讓基於 Unicode 的文本處理更爲方便,也可使用 byte 型進行默認字符串處理
//遍歷字符串 func checkString() { s := "hello世界" for i := 0; i < len(s); i++ { fmt.Printf("%v(%c)", s[i], s[i]) } fmt.Printf() for _, j := range s { fmt.Printf("%v(%c)", r, r) } fmt.Printf() } //104(h)101(e)108(l)108(l)111(o)228(ä)184(¸)150()231(ç)149()140() //104(h)101(e)108(l)108(l)111(o)19990(世)30028(界)
由於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表示要轉換的類型。表達式包括變量、複雜算子和函數返回值等
Println 與Printf 都是fmt 包中的公共方法,在須要打印信息時須要用到這二個函數
Println :能夠打印出字符串,和變量 ,會自動換行 Printf : 只能夠打印出格式化的字符串,能夠輸出字符串類型的變量,不能夠輸出整形變量和整形,不會自動換行