字符串,string,一串固定長(zhǎng)度的字符連接起來(lái)的字符集合。Go語(yǔ)言的字符串是使用UTF-8編碼的。UTF-8是Unicode的實(shí)現(xiàn)方式之一。
創(chuàng)新互聯(lián)建站主要從事網(wǎng)站制作、做網(wǎng)站、網(wǎng)頁(yè)設(shè)計(jì)、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)永昌,10多年網(wǎng)站建設(shè)經(jīng)驗(yàn),價(jià)格優(yōu)惠、服務(wù)專(zhuān)業(yè),歡迎來(lái)電咨詢建站服務(wù):18982081108Go語(yǔ)言原生支持字符串。使用雙引號(hào)("")或反引號(hào)(``)定義。
雙引號(hào):"", 用于單行字符串。
反引號(hào):``,用于定義多行字符串,內(nèi)部會(huì)原樣解析。
示例:
// 單行
"心有猛虎,細(xì)嗅薔薇"
// 多行
`
大風(fēng)歌
大風(fēng)起兮云飛揚(yáng)。
威加海內(nèi)兮歸故鄉(xiāng)。
安得猛士兮守四方!
`
字符串支持轉(zhuǎn)義字符,列表如下:
"\u5eb7"
就是 "康"Go語(yǔ)言中字符串的頂層結(jié)構(gòu)是由一個(gè)指針和長(zhǎng)度構(gòu)成的。使用 unsafe.Sizeof("") 會(huì)得到16長(zhǎng)度,其中8個(gè)字節(jié)是指針,指向字符串的內(nèi)存地址,8個(gè)是存儲(chǔ)字符串的長(zhǎng)度。
以下是針對(duì)字符串的操作總結(jié),主要來(lái)自于Go語(yǔ)言的API的說(shuō)明和測(cè)試。
可以使用[index]方式,訪問(wèn)到字符串中的字符??梢栽L問(wèn),不可以修改。
s := "Hank"
fmt.Printf("%c", s[2])
// 返回 n
多字節(jié)字符的處理,請(qǐng)參考 unicode/utf8 包的相關(guān)說(shuō)明。
例如:
import "unicode/utf8"
utf8.RuneCountInString("小韓說(shuō)課")
// 返回 4
utf-8
是變長(zhǎng)字符集,英文標(biāo)點(diǎn)占用1個(gè)字節(jié),中文占用3個(gè)字節(jié)。
len("Hank康")
// 返回 7
"Hello" + " " + "Hank"
字符串比較,比較機(jī)制是字符的對(duì)稱(chēng)比較。
"abc" > "bbcd"
// 結(jié)果為false
字符串比較,比較機(jī)制是字符的對(duì)稱(chēng)比較。返回值為:
strings.Compare("abc", "abcd")
// 返回 1
檢測(cè)字符串 substr 是否在 s 中。
strings.Contains("foobar", "foo")
// 返回 true
strings.Contains("fobar", "foo")
// 返回 false
檢測(cè)字符串 chars 的中任意字符是否出現(xiàn)在 s 中。
fmt.Println(strings.ContainsAny("Hank", "kang"))
// 返回 true
fmt.Println(strings.ContainsAny("Hank", "go"))
// 返回 false
檢測(cè) rune字符是否出現(xiàn)在 s 中。
strings.ContainsRune("Hank", 'a')
// 返回 true
strings.ContainsRune("Hank", 97)
// 返回 true,a的碼值97
統(tǒng)計(jì)字符串 s 中非重疊substr的數(shù)量。若統(tǒng)計(jì)空字符串"",會(huì)返回 s 的長(zhǎng)度加1。
strings.Count("HanZhongKang", "n")
// 返回 3
strings.Count("Hank", "")
// 返回 5,"Hank"每個(gè)rune的前后都算
檢測(cè)字符串 s 和 t 在忽略大小寫(xiě)的情況下是否相等。
strings.EqualFold("Hank", "hank")
// 返回 true
返回使用空格分割的字符串 s,結(jié)果為切片。
strings.Fields("Han Zhong Kang")
// 返回 []string, ["Han", "Zhong", "Kang"]
使用函數(shù)確定分隔符,來(lái)分割字符串 s。結(jié)果是切片。
// ,|/ 都是分隔符
fn := func(c rune) bool {
return strings.ContainsRune(",|/", c)
}
strings.FieldsFunc("go,python,c++/c,Js|JavaScript", fn)
// 返回 ["go" "python" "c++" "c" "Js" "JavaScript"]
檢測(cè)字符串 s 是否以字符串 prefix 作為前綴。
strings.HasPrefix("Gopher", "Go")
// 返回 true
檢測(cè)字符串 s 是否以字符串 suffix 作為后綴。
strings.HasSuffix("Gopher", "er")
// 返回 true
返回字符串 substr 在字符串 s 中第一次出現(xiàn)的索引位置,若沒(méi)有出現(xiàn),返回-1。
strings.Index("Gopher", "ph")
// 返回 2
返回字符串 chars 中的任意字符在字符串 s 中第一次出現(xiàn)的索引位置,若沒(méi)有出現(xiàn),返回-1。
strings.IndexAny("Gopher", "lmno")
// 返回 1
返回byte字符 c 在字符串 s 中第一次出現(xiàn)的索引位置,若沒(méi)有出現(xiàn),返回-1。
strings.IndexByte("Gopher", 'h')
// 返回 3
返回字符串 s 中第一次滿足函數(shù) f 的rune字符的索引位置,若沒(méi)有出現(xiàn),返回-1。
fn := func(c rune) bool {
return strings.ContainsRune(",|/", c)
}
strings.IndexFunc("go,python,c++/c,Js|JavaScript", fn)
// 返回 2
返回run字符 r 在字符串 s 中第一次出現(xiàn)的索引位置,若沒(méi)有出現(xiàn),返回-1。
strings.IndexRune("小韓說(shuō)課", '說(shuō)')
// 返回 6
使用分隔符 sep 連接字符串切片 a。
ss := []string{"Go", "Hank", "Python", "PHP"}
strings.Join(ss, "-")
// 返回 "Go-Hank-Python-PHP"
返回字符串 substr 在字符串 s 中最后一次出現(xiàn)的索引位置,若沒(méi)有出現(xiàn),返回-1。
strings.LastIndex("Hankang", "an")
// 返回 4
返回字符串 chars 中的任意字符在字符串 s 中最后一次出現(xiàn)的索引位置,若沒(méi)有出現(xiàn),返回-1。
strings.LastIndexAny("Hankang", "lmno")
// 返回 5
返回byte字符 c 在字符串 s 中最后一次出現(xiàn)的索引位置,若沒(méi)有出現(xiàn),返回-1。
strings.LastIndexByte("Hankang", 'n')
// 返回 5
返回字符串 s 中字后一次滿足函數(shù) f 的rune字符的索引位置,若沒(méi)有出現(xiàn),返回-1。
fn := func(c rune) bool {
return strings.ContainsRune(",|/", c)
}
strings.LastIndexFunc("go,Js|JavaScript", fn)
// 返回 5
返回字符串 s 中的每個(gè)字符經(jīng)過(guò)映射函數(shù) mapping 處理之后的字符串。
fn := func(c rune) rune {
if strings.ContainsRune(",|/", c) {
return '-'
} else {
return c
}
}
strings.Map(fn, "go,Js|JavaScript")
// 返回 "go-Js-JavaScript"
返回將字符串 s 重復(fù) count 的字符串。
strings.Repeat("la~", 3)
// 返回值 "la~la~la~"
在字符串 s 中使用字符串 new 替換字符串 old,使用 n 限定替換次數(shù),n設(shè)置為負(fù)數(shù)表示沒(méi)有限制。返回替換結(jié)果。
strings.Replace("han zhong kang", "n", "N", 2)
// 返回 "haN zhoNg kang"
使用分隔符 sep 分割字符串 s,返回字符串切片
strings.Split("go-Js-JavaScript", "-")
// 返回 ["go", "Js", "JavaScript"]
在分隔符 sep 后分割字符串 s,返回字符串切片
strings.SplitAfter("go-Js-JavaScript", "-")
// 返回 ["go-", "Js-", "JavaScript"]
在分隔符 sep 后分割字符串 s,使用 n 限定分割的元素?cái)?shù)量,n<0全部子字符串,n>0最后一個(gè)子字符串包含余下內(nèi)容,n==0返回nil。返回子字符串切片。
strings.SplitAfterN("go-Js-JavaScript", "-", 2)
// 返回 ["go-", "Js-JavaScript"]
在分隔符 sep 分割字符串 s,使用 n 限定分割的元素?cái)?shù)量,n<0全部子字符串,n>0最后一個(gè)子字符串包含余下內(nèi)容,n==0返回nil。返回子字符串切片。
strings.SplitN("go-Js-JavaScript", "-", 2)
// 返回 ["go", "Js-JavaScript"]
返回Title化的字符串。
strings.Title("hello Hank's go")
// 返回 "Hello Hank's Go"
轉(zhuǎn)換字符串 s 到小寫(xiě)。
strings.ToLower("Hank's Go Guide")
// 返回 "hank's go guide"
使用特定的規(guī)則轉(zhuǎn)換字符串 s 到小寫(xiě)。
strings.ToLowerSpecial(unicode.TurkishCase, "?nnek ??")
// 返回 ?nnek i?
返回全部字符都Title化的字符串。
strings.Title("hello Hank's go")
// 返回 "HELLO HANK'S GO"
使用特定的規(guī)則將全部字符都Title化。
strings.ToTitleSpecial(unicode.TurkishCase, "dünyan?n ilk borsa yap?s? Aizonai kabul edilir")
// 返回 "DüNYANIN ?LK BORSA YAPISI A?ZONA? KABUL ED?L?R"
將字符串 s 中所有字符轉(zhuǎn)換為大寫(xiě)。
strings.ToUpper("hello Hank's go")
// 返回 "HELLO HANK'S GO"
使用特定的規(guī)則將字符串 s 中所有字符轉(zhuǎn)換為大寫(xiě)。
strings.ToUpperSpecial(unicode.TurkishCase, "?rnek i?")
// 返回 "?RNEK ??"
截取字符串 s 兩端包裹的特定字符集 cutset。
strings.Trim(" user name ", " ")
// 返回 "user name"
截取字符串 s 兩端滿足函數(shù) f 的字符。
fn := func(c rune) bool {
return strings.ContainsRune(",|/", c)
}
strings.TrimFunc("|/user name,/", fn)
// 返回 "user name"
截取字符串 s 左邊包裹的特定字符集 cutset。
strings.TrimLeft(" user name ", " ")
// 返回 "user name "
截取字符串 s 左邊滿足函數(shù) f 的字符。
fn := func(c rune) bool {
return strings.ContainsRune(",|/", c)
}
strings.TrimLeftFunc("|/user name,/", fn)
// 返回 "user name,/"
截取字符串 s 的前綴 prefix。
strings.TrimPrefix("hank_goGuide", "hank_")
// 返回 "goGuide"
截取字符串 s 右邊包裹的特定字符集 cutset。
strings.TrimRight(" user name ", " ")
// 返回 " user name"
截取字符串 s 右邊滿足函數(shù) f 的字符。
fn := func(c rune) bool {
return strings.ContainsRune(",|/", c)
}
strings.TrimRightFunc("|/user name,/", fn)
// 返回 "|/user name"
截取字符串 s 兩端的空白字符。
strings.TrimSpace(" \t\n Hello, Gophers \n\t\r\n")
// 返回 "Hello, Gophers"
截取字符串 s 的后綴 suffix。
strings.TrimSuffix("goGuide_beta", "_beta")
// 返回 "goGuide"
完!
原文出自:小韓說(shuō)課
微信關(guān)注:小韓說(shuō)課
創(chuàng)新互聯(lián)www.cdcxhl.cn,專(zhuān)業(yè)提供香港、美國(guó)云服務(wù)器,動(dòng)態(tài)BGP最優(yōu)骨干路由自動(dòng)選擇,持續(xù)穩(wěn)定高效的網(wǎng)絡(luò)助力業(yè)務(wù)部署。公司持有工信部辦法的idc、isp許可證, 機(jī)房獨(dú)有T級(jí)流量清洗系統(tǒng)配攻擊溯源,準(zhǔn)確進(jìn)行流量調(diào)度,確保服務(wù)器高可用性。佳節(jié)活動(dòng)現(xiàn)已開(kāi)啟,新人活動(dòng)云服務(wù)器買(mǎi)多久送多久。