go語言中str是什麼意思

2022-12-27 14:00:19

在go語言中,str指的是「字串」,是一個不可改變的位元組序列。字串可以包含任意的資料,但是通常是用來包含可讀的文字,字串是 UTF-8 字元的一個序列(當字元為 ASCII 碼錶上的字元時則佔用 1 個位元組,其它字元根據需要佔用 2-4 個位元組)。字串是一種值型別,且值不可變,即建立某個文字後將無法再次修改這個文字的內容,更深入地講,字串是位元組的定長陣列。

本教學操作環境:windows7系統、GO 1.18版本、Dell G3電腦。

在go語言中,str指的是「字串」。

一個字串是一個不可改變的位元組序列,字串可以包含任意的資料,但是通常是用來包含可讀的文字,字串是 UTF-8 字元的一個序列(當字元為 ASCII 碼錶上的字元時則佔用 1 個位元組,其它字元根據需要佔用 2-4 個位元組)。

Go語言中字串的內部實現使用 UTF-8 編碼,通過 rune 型別,可以方便地對每個 UTF-8 字元進行存取。當然,Go語言也支援按照傳統的 ASCII 碼方式逐字元進行存取。

UTF-8 是一種被廣泛使用的編碼格式,是文字檔案的標準編碼,其中包括 XML 和 JSON 在內也都使用該編碼。由於該編碼對佔用位元組長度的不定性,在Go語言中字串也可能根據需要佔用 1 至 4 個位元組,這與其它程式語言如 C++、Java 或者 Python 不同(Java 始終使用 2 個位元組)。Go語言這樣做不僅減少了記憶體和硬碟空間佔用,同時也不用像其它語言那樣需要對使用 UTF-8 字元集的文字進行編碼和解碼。

字串是一種值型別,且值不可變,即建立某個文字後將無法再次修改這個文字的內容,更深入地講,字串是位元組的定長陣列。

定義字串

可以使用雙引號""來定義字串,字串中可以使用跳脫字元來實現換行、縮排等效果,常用的跳脫字元包括:

  • \n:換行符

  • \r:回車符

  • \t:tab 鍵

  • \u 或 \U:Unicode 字元

  • \\:反斜槓自身

package main
import (
    "fmt"
)
func main() {
    var str = "PHP中文網\nGo語言教學"
    fmt.Println(str)
}
登入後複製

執行結果為:

1.png

一般的比較運運算元(==、!=、<、<=、>=、>)是通過在記憶體中按位元組比較來實現字串比較的,因此比較的結果是字串自然編碼的順序。字串所佔的位元組長度可以通過函數 len() 來獲取,例如 len(str)。

字串的內容(純位元組)可以通過標準索引法來獲取,在方括號[ ]內寫入索引,索引從 0 開始計數:

  • 字串 str 的第 1 個位元組:str[0]

  • 第 i 個位元組:str[i - 1]

  • 最後 1 個位元組:str[len(str)-1]

需要注意的是,這種轉換方案只對純 ASCII 碼的字串有效。

注意:獲取字串中某個位元組的地址屬於非法行為,例如 &str[i]

字串拼接符「+」

兩個字串 s1 和 s2 可以通過 s := s1 + s2 拼接在一起。將 s2 追加到 s1 尾部並生成一個新的字串 s。

可以通過下面的方式來對程式碼中多行的字串進行拼接:

str := "Beginning of the string " +
"second part of the string"
登入後複製

提示:因為編譯器會在行尾自動補全分號,所以拼接字串用的加號「+」必須放在第一行末尾。

也可以使用「+=」來對字串進行拼接:

s := "hel" + "lo,"
s += "world!"
fmt.Println(s) //輸出 「hello, world!」
登入後複製

定義多行字串

在Go語言中,使用雙引號書寫字串的方式是字串常見表達方式之一,被稱為字串字面量(string literal),這種雙引號字面量不能跨行,如果想要在原始碼中嵌入一個多行字串時,就必須使用`反引號,程式碼如下:

const str = `第一行
第二行
第三行
\r\n
`
fmt.Println(str)
登入後複製

程式碼執行結果:

2.png

反引號`,是鍵盤上 1 鍵左邊的鍵,兩個反引號間的字串將被原樣賦值到 str 變數中。

在這種方式下,反引號間換行將被作為字串中的換行,但是所有的跳脫字元均無效,文字將會原樣輸出。

多行字串一般用於內嵌原始碼和內嵌資料等,程式碼如下:

const codeTemplate = `// Generated by github.com/davyxu/cellnet/
protoc-gen-msg
// DO NOT EDIT!{{range .Protos}}
// Source: {{.Name}}{{end}}
package {{.PackageName}}
{{if gt .TotalMessages 0}}
import (
    "github.com/davyxu/cellnet"
    "reflect"
    _ "github.com/davyxu/cellnet/codec/pb"
)
{{end}}
func init() {
    {{range .Protos}}
    // {{.Name}}{{range .Messages}}
    cellnet.RegisterMessageMeta("pb","{{.FullName}}", reflect.TypeOf((*{{.Name}})(nil)).Elem(), {{.MsgID}})    {{end}}
    {{end}}
}
登入後複製

這段程式碼只定義了一個常數 codeTemplate,型別為字串,使用`定義,字串的內容為一段程式碼生成中使用到的 Go 原始碼格式。

`間的所有程式碼均不會被編譯器識別,而只是作為字串的一部分。

字串字面量

在Go語言中,字串字面量是通過兩種不同的方式建立的:

  • 使用雙引號("":在這裡,字串字面量使用雙引號("")建立。此類字串支援跳脫字元,如下表所示,但不跨越多行。這種型別的字串文字在Golang程式中被廣泛使用。

跳脫符描述
\\反斜槓(\)
\000具有給定的3位8位元八進位製程式碼點的Unicode字元
\’單引號(')。僅允許在字元文字中使用
\」雙引號("")。僅允許在解釋的字串文字中使用
\aASCII鈴聲(BEL)
\bASCII退格鍵(BS)
\fASCII換頁(FF)
\nASCII換行符(LF)
\rASCII回車(CR)
\tASCII標籤(TAB)
\uhhhh具有給定的4位元16位元十六進位製程式碼點的Unicode字元。

具有給定的8位元32位元十六進位製程式碼點的Unicode字元。
\vASCII垂直製表符(VT)
\xhh具有給定的2位8位元十六進位製程式碼點的Unicode字元。
  • 使用反引號('':此處,字串文字是使用反引號('')建立的,也稱為raw literals(原始文字)。原始文字不支援跳脫字元,可以跨越多行,並且可以包含除反引號之外的任何字元。通常,它用於在正規表示式和HTML中編寫多行訊息。

package main

import "fmt"

func main() {

    //建立並初始化
    //帶有字串文字的變數
    //使用雙引號
    My_value_1 := "Welcome to nhooo"

    //新增跳脫字元
    My_value_2 := "Welcome!\nnhooo"

    //使用反引號
    My_value_3 := `Hello!nhooo`

    //新增跳脫字元

    //原始文字
    My_value_4 := `Hello!\nnhooo`

    //顯示
    fmt.Println("String 1: ", My_value_1)
    fmt.Println("String 2: ", My_value_2)
    fmt.Println("String 3: ", My_value_3)
    fmt.Println("String 4: ", My_value_4)
}
登入後複製

輸出:

3.png

關於字串的要點

  • 字串是不可變的:在Go語言中,一旦建立了字串,則字串是不可變的,無法更改字串的值。換句話說,字串是唯讀的。如果嘗試更改,則編譯器將引發錯誤。

//字串是不可變的
package main 
  
import "fmt"
  
func main() { 
  
        //建立和初始化字串
        //使用簡寫宣告
    mystr := "Welcome to nhooo"
  
    fmt.Println("String:", mystr) 
  
    /* 果你試圖改變字串的值,編譯器將丟擲一個錯誤,例如, 
     cannot assign to mystr[1] 
       mystr[1]= 'G' 
       fmt.Println("String:", mystr) 
    */
  
}
登入後複製

輸出:

4.png

  • 如何遍歷字串?:您可以使用for range迴圈遍歷字串。此迴圈可以在Unicode程式碼點上迭代一個字串。

語法:

for index, chr:= range str{
     // 語句..
}
登入後複製

在這裡,索引是儲存UTF-8編碼程式碼點的第一個位元組的變數,而chr是儲存給定字串的字元的變數,str是字串。

//遍歷字串
//使用for範圍迴圈
package main

import "fmt"

func main() {

    //字串作為for迴圈中的範圍
    for index, s := range "nhooo" {

        fmt.Printf("%c 索引值是 %d\n", s, index)
    }
}
登入後複製

輸出:

5.png

  • 如何存取字串的單個位元組?:字串是一個位元組,因此,我們可以存取給定字串的每個位元組。

//存取字串的位元組
package main

import "fmt"

func main() {

    //建立和初始化一個字串
    str := "Welcome to nhooo"

    //存取給定字串的位元組
    for c := 0; c < len(str); c++ {

        fmt.Printf("\n字元 = %c 位元組 = %v", str[c], str[c])
    }
}
登入後複製

6.png

  • 如何從切片建立字串?:在Go語言中,允許您從位元組切片建立字串。

//從切片建立一個字串 
package main 
  
import "fmt"
  
func main() { 
  
    //建立和初始化一個位元組片
    myslice1 := []byte{0x47, 0x65, 0x65, 0x6b, 0x73} 
  
    //從切片建立字串
    mystring1 := string(myslice1) 
  
    //顯示字串
    fmt.Println("String 1: ", mystring1) 
  
    //建立和初始化一個符文切片 
    myslice2 := []rune{0x0047, 0x0065, 0x0065, 0x006b, 0x0073} 
  
    //從切片建立字串
    mystring2 := string(myslice2) 
  
    //顯示字串
    fmt.Println("String 2: ", mystring2) 
}
登入後複製

7.png

  • 如何查詢字串的長度?:在Golang字串中,可以使用兩個函數(一個是len(),另一個是RuneCountInString())來找到字串的長度。UTF-8包提供了RuneCountInString()函數,該函數返回字串中存在的符文總數。len()函數返回字串的位元組數。

//查詢字串的長度
package main

import (
    "fmt"
    "unicode/utf8"
)

func main() {

    //建立和初始化字串
    //使用簡寫宣告
    mystr := "Welcome to nhooo ??????"

    //查詢字串的長度
    //使用len()函數
    length1 := len(mystr)

    //使用RuneCountInString()函數
    length2 := utf8.RuneCountInString(mystr)

    //顯示字串的長度
    fmt.Println("string:", mystr)
    fmt.Println("Length 1:", length1)
    fmt.Println("Length 2:", length2)

}
登入後複製

8.png

【相關推薦:Go視訊教學、】

以上就是go語言中str是什麼意思的詳細內容,更多請關注TW511.COM其它相關文章!