Go基礎之基本數據類型

Go基礎之基本數據類型

基本數據類型

整形

  • int八、int1六、int3二、int64
  • 無符號整形:uint八、uint1六、uint3二、uint64
  • 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 無符號整型,用於存放一個指針

在使用intuint類型時,不能假定它是32位或64位的整型,而是考慮intuint可能在不一樣平臺上的差別數組

注意事項 獲取對象的長度的內建len()函數返回的長度能夠根據不一樣平臺的字節長度進行變化。實際使用中,切片或 map 的元素數量等均可以用int來表示。在涉及到二進制傳輸、讀寫文件的結構描述時,爲了保持文件的結構不會受到不一樣編譯目標平臺字節長度的影響,不要使用intuint安全

浮點型

Go語言支持兩種浮點型數:float32float64函數

打印浮點數時,可使用fmt包配合動詞%fui

package main
import (
     "fmt"
     "math"
)

func main() {
  fmt.Printf("%f\n", math.Pi)
  fmt.Printf("%.2f\n", math.Pi)
}

布爾

Go語言中以bool類型進行聲明布爾型數據編碼

注意:操作系統

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

字符串

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操做

Go語言佔位符

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

byte和rune類型

組成每一個字符串的元素叫作「字符」,能夠經過遍歷或者單個獲取字符串元素得到字符。 字符用單引號(’)包裹起來對象

var a := 'h'
var b := '世'

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

  1. uint8類型,或者叫 byte 型,表明了ASCII碼的一個字符。
  2. 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表示要轉換的類型。表達式包括變量、複雜算子和函數返回值等

go語言中Println和Printf的區別

Println 與Printf 都是fmt 包中的公共方法,在須要打印信息時須要用到這二個函數

Println :能夠打印出字符串,和變量 ,會自動換行 Printf : 只能夠打印出格式化的字符串,能夠輸出字符串類型的變量,不能夠輸出整形變量和整形,不會自動換行

相關文章
相關標籤/搜索