欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識庫 > Go語言中多字節字符的處理方法詳解

Go語言中多字節字符的處理方法詳解

熱門標簽:江西轉化率高的羿智云外呼系統 西部云谷一期地圖標注 南通如皋申請開通400電話 廣州呼叫中心外呼系統 高德地圖標注口訣 中國地圖標注省會高清 學海導航地圖標注 浙江高速公路地圖標注 地圖標注的汽車標

1 概述

Go語言的字符串是使用 UTF-8 編碼的。UTF-8 是 Unicode 的實現方式之一。本文內容包括:UTF-8 和 Unicode 的關系,Go語言提供的 unicode 包和 unicode/utf8 包的使用。

下面話不多說了,來一起看看詳細的介紹吧

2 UTF-8 和 Unicode 的關系

Unicode一種字符集,是國際標誰化組織(ISO)設計的一個包括了地球上所有文化、所有字母和符號 的編碼。他們叫它 Universal Multiple-Octet Coded Character Set,簡稱 UCS,也就是 Unicode。Unicode 為每一個 字符 分配一個唯一的 碼點(Code Point),就是一個唯一的值。例如 康 的碼點就是 24247,十六進制為 5eb7。

Unicode 字符集僅僅定義了字符與碼點的對應關系,但是并沒有定義該如何編碼(存儲)這個碼值,這就導致了很多問題。例如由于字符的碼值不同,導致所需要的存儲空間是不一致的,計算機不能確定接下來的字符是占用幾個字節。還有就是如果采用固定的長度假設都是4個字節來存儲碼點值,那么會導致空間的額外浪費,因為 ascii 碼字符其實僅僅需要一個字節的空間。

UTF-8 就是解決如何為 Unicode 編碼而設計的一種編碼規則。可以說 UTF-8 是 Unicode 的實現方式之一。其特點是一種變長編碼,使用1到4個字節表示一個字符,根據不同的符號而變化長度。UTF-8 的編碼規則有二:

  • 對于單字節的符號,字節的第一位設為0,后面7位為這個符號的 Unicode 碼。因此對于ASCII碼字符,UTF-8 編碼和 ASCII 碼是相同的。
  • 對于 n 字節的符號(n > 1,2到4),第一個字節的前n位都設為1,第n + 1 位設為 0,后面字節的前兩位一律設為10。剩下的沒有提及的二進制位,全部為這個符號的 Unicode 碼。

以下是編碼規則:

Unicode    | UTF-8
--------------------------------------------------------- 
0000 0000-0000 007F | 0xxxxxxx
0000 0080-0000 07FF | 110xxxxx 10xxxxxx
0000 0800-0000 FFFF | 1110xxxx 10xxxxxx 10xxxxxx
0001 0000-0010 FFFF | 11110xxx 10xxxxxx 10xxxxxx 10xxxxxx
---------------------------------------------------------

Go語言中,對于 Unicode 和 UTF-8 使用了 unicode 和 unicode/utf8 包來實現,下面是閱讀 API 的總結和說明。

3 Unicode 包

Go語言中,提供了 Unicode 包,處理與 Unicode 相關的操作,整理如下:

Is(rangeTab *RangeTable, r rune) bool

檢測 rune r 是否在 rangeTable 指定的字符范圍內。

rangeTable 一個 Unicode 碼值集合,通常使用 unicode 包中定義的集合。

判斷字符是否出現在漢字集合中:

unicode.Is(unicode.Scripts["Han"], 'k')
// 返回 false
unicode.Is(unicode.Scripts["Han"], '康')
// 返回 true

In(r rune, ranges …*RangeTable) bool

檢測 rune r 是否在多個 rangeTable 指定的字符范圍內。

rangeTable 一個 Unicode 碼值集合,通常使用 unicode 包中定義的集合。

unicode.In('康', unicode.Scripts["Han"], unicode.Scripts["Latin"])
// 返回 true
unicode.In('k', unicode.Scripts["Han"], unicode.Scripts["Latin"])
// 返回 true

IsOneOf(ranges []*RangeTable, r rune) bool

檢測 rune r 是否在 rangeTable ranges 指定的字符范圍內。與 In 功能類似,推薦使用 In。

IsSpace(r rune) bool

檢測字符 rune r 是否是空白字符。在Latin-1字符空間中,空白字符為:

'\t', '\n', '\v', '\f', '\r', ' ', U+0085 (NEL), U+00A0 (NBSP)

其它的空白字符請參見策略Z和屬性Pattern_White_Space。

IsDigit(r rune) bool

檢測字符 rune r 是否是十進制數字字符。

unicode.IsDigit('9')
// 返回 true
unicode.IsDigit('k')
// 返回 false

IsNumber(r rune) bool

檢測字符 rune r 是否是 Unicode 數字字符。

IsLetter(r rune) bool

檢測一個字符 rune r 是否是字母

unicode.IsLetter('9')
// 返回 false
unicode.IsLetter('k')
// 返回 true

IsGraphic(r rune) bool

一個字符 rune r 是否是 unicode 圖形字符。圖形字符包括字母、標記、數字、符號、標點、空白。

unicode.IsGraphic('9')
// 返回 true
unicode.IsGraphic(',')
// 返回 true

IsControl(r rune) bool

檢測一個字符 rune r 是否是 unicode 控制字符。

IsMark(r rune) bool

檢測一個字符 rune r 是否是標記字符。

IsPrint(r rune) bool

檢測一個字符 rune r 是否是的可打印字符,基本與圖形字符一致,除ASCII空白字符U+0020。

IsPunct(r rune) bool

檢測一個字符 rune r 是否是 unicode標點字符。

unicode.IsPunct('9')
// 返回 false
unicode.IsPunct(',')
// 返回 true

IsSymbol(r rune) bool

檢測一個字符 rune r 是否是 unicode 符號字符。

IsLower(r rune) bool

檢測一個字符 rune r 是否是小寫字母。

unicode.IsLower('h')
// 返回 true
unicode.IsLower('H')
// 返回 false

IsUpper(r rune) bool

檢測一個字符 rune r 是否是大寫字母。

unicode.IsUpper('h')
// 返回 false
unicode.IsUpper('H')
// 返回 true

IsTitle(r rune) bool

檢測一個字符 rune r 是否是Title字符。大部分字符的 Title 格式就是其大寫格式,少數字符的 Title 格式是特殊字符,例如 ᾏᾟᾯ。

unicode.IsTitle('ᾯ')
// 返回 true
unicode.IsTitle('h')
// 返回 false
unicode.IsTitle('H')
// 返回 true

To(_case int, r rune) rune

將字符 rune r 轉換為指定的格式,格式_case支持:unicode.UpperCase、unicode.LowerCase、unicode.TitleCase

unicode.To(unicode.UpperCase, 'h')
// 返回 H

ToLower(r rune) rune

將字符 rune r 轉換為小寫。

unicode.ToLower('H')
// 返回 h

func (SpecialCase) ToLower

將字符 rune r 轉換為小寫。優先使用映射表 SpecialCase。

映射表 SpecialCase 是特定語言環境下大小寫的映射表。主要應用于一些歐洲字符,例如土耳其 TurkishCase。

unicode.TurkishCase.ToLower('İ')
// 返回 i

ToUpper(r rune) rune

將字符 rune r 轉換為大寫。

unicode.ToUpper('h')
// 返回 H

func (SpecialCase) ToUpper

將字符 rune r 轉換為大寫。優先使用映射表 SpecialCase。

映射表 SpecialCase 是特定語言環境下大小寫的映射表。主要應用于一些歐洲字符,例如土耳其 TurkishCase。

unicode.TurkishCase.ToUpper('i')
// 返回 İ

ToTitle(r rune) rune

將字符 rune r 轉換為 Title 字符。

unicode.ToTitle('h')
// 返回 H

func (SpecialCase) ToTitle

將字符 rune r 轉換為 Title 字符。優先使用映射表 SpecialCase。

映射表 SpecialCase 是特定語言環境下大小寫的映射表。主要應用于一些歐洲字符,例如土耳其 TurkishCase。

unicode.TurkishCase.ToTitle('i')
// 返回 İ

SimpleFold(r rune) rune

在 unicode 標準字符映射中查找與 rune r 互相對應的 unicode 碼值。向碼值大的方向循環查找。互相對應指的是同一個字符可能出現的多種寫法。

unicode.SimpleFold('H')
// 返回 h
unicode.SimpleFold('Φ')) 
// 返回 φ

4 unicode/utf8 包

DecodeLastRune(p []byte) (r rune, size int)

解碼 []byte p 中最后一個 UTF-8 編碼序列,返回該碼值和長度。

utf8.DecodeLastRune([]byte("小韓說課"))
// 返回 35838 3
// 35838 就是課的 unicode 碼值

DecodeLastRuneInString(s string) (r rune, size int)

解碼 string s 中最后一個 UTF-8 編碼序列,返回該碼值和長度。

utf8.DecodeLastRuneInString("小韓說課")
// 返回 35838 3
// 35838 就是課的 unicode 碼值

DecodeRune(p []byte) (r rune, size int)

解碼 []byte p 中第一個 UTF-8 編碼序列,返回該碼值和長度。

utf8.DecodeRune([]byte("小韓說課"))
// 返回 23567 3
// 23567 就是 小 的 unicode 碼值

DecodeRuneInString(s string) (r rune, size int)

解碼 string s 中第一個 UTF-8 編碼序列,返回該碼值和長度。

utf8.DecodeRuneInString("小韓說課")
// 返回 23567 3
// 23567 就是 小 的 unicode 碼值

EncodeRune(p []byte, r rune) int

將 rune r 的 UTF-8 編碼序列寫入 []byte p,并返回寫入的字節數。p 滿足足夠的長度。

buf := make([]byte, 3)
n := utf8.EncodeRune(buf, '康')
fmt.Println(buf, n)
// 輸出 [229 186 183] 3

FullRune(p []byte) bool

檢測 []byte p 是否包含一個完整 UTF-8 編碼。

buf := []byte{229, 186, 183} // 康
utf8.FullRune(buf)
// 返回 true
utf8.FullRune(buf[:2])
// 返回 false

FullRuneInString(s string) bool

檢測 string s 是否包含一個完整 UTF-8 編碼。

buf := "康" // 康
utf8.FullRuneInString(buf)
// 返回 true
utf8.FullRuneInString(buf[:2])
// 返回 false

RuneCount(p []byte) int

返回 []byte p 中的 UTF-8 編碼的碼值的個數。

buf := []byte("小韓說課")
len(buf)
// 返回 12
utf8.RuneCount(buf)
// 返回 4

RuneCountInString(s string) (n int)

返回 string s 中的 UTF-8 編碼的碼值的個數。

buf := "小韓說課"
len(buf)
// 返回 12
utf8.RuneCountInString(buf)
// 返回 4

RuneLen(r rune) int

返回 rune r 編碼后的字節數。

utf8.RuneLen('康')
// 返回 3
utf8.RuneLen('H')
// 返回 1

RuneStart(b byte) bool

檢測字節 byte b 是否可以作為某個 rune 編碼的第一個字節。

buf := "小韓說課"
utf8.RuneStart(buf[0])
// 返回 true
utf8.RuneStart(buf[1])
// 返回 false
utf8.RuneStart(buf[3])
// 返回 true

Valid(p []byte) bool

檢測切片 []byte p 是否包含完整且合法的 UTF-8 編碼序列。

valid := []byte("小韓說課")
invalid := []byte{0xff, 0xfe, 0xfd}
utf8.Valid(valid)
// 返回 true
utf8.Valid(invalid)
// 返回 false

ValidRune(r rune) bool

檢測字符 rune r 是否包含完整且合法的 UTF-8 編碼序列。

valid := 'a'
invalid := rune(0xfffffff)
fmt.Println(utf8.ValidRune(valid))
// 返回 true
fmt.Println(utf8.ValidRune(invalid))
// 返回 false

ValidString(s string) bool

檢測字符串 string s 是否包含完整且合法的 UTF-8 編碼序列。

valid := "小韓說課"
invalid := string([]byte{0xff, 0xfe, 0xfd})
fmt.Println(utf8.ValidString(valid))
// 返回 true
fmt.Println(utf8.ValidString(invalid))
// 返回 false

完!

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • Go語言range關鍵字循環時的坑
  • Go語言中http和mysql的實現代碼
  • go語言中int和byte轉換方式
  • Go語言中的字符串處理方法示例詳解
  • Go語言實現互斥鎖、隨機數、time、List
  • Go語言中 Channel 詳解
  • go語言中strings包的用法匯總
  • Go語言的JSON處理詳解
  • Go語言的文件操作代碼匯總
  • Golang數組的傳遞詳解

標簽:常州 德宏 東營 保定 曲靖 貴州 許昌 吐魯番

巨人網絡通訊聲明:本文標題《Go語言中多字節字符的處理方法詳解》,本文關鍵詞  語,言中,多,字節,字符,的,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Go語言中多字節字符的處理方法詳解》相關的同類信息!
  • 本頁收集關于Go語言中多字節字符的處理方法詳解的相關信息資訊供網民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    久久精品亚洲精品国产欧美| 国产不卡在线视频| 黑人玩弄人妻一区二区三区| 在线精品观看国产| 亚洲人成在线播放网站岛国| 不卡在线视频中文字幕| av最新在线观看| 国产农村妇女精品| 国产老女人精品毛片久久| 少妇精品无码一区二区免费视频| 精品国产第一区二区三区观看体验| 日韩高清国产一区在线| 色呦呦一区二区| 精品欧美乱码久久久久久1区2区| 免费精品99久久国产综合精品| 爱爱免费小视频| 久久婷婷一区二区三区| 国产综合久久久久影院| 四虎永久免费地址| 国产精品成人一区二区艾草| 99久久精品久久久久久清纯| 欧美视频一区二区三区四区 | 亚洲精品ww久久久久久p站| av成人动漫在线观看| 91搞黄在线观看| 亚洲综合一区在线| 2一3sex性hd| 日韩精品在线一区二区| 精品一区二区综合| 免费在线观看黄色小视频| 国产精品福利一区| 中文字幕avav| 91精品国产品国语在线不卡| 久久99精品久久久久久动态图| 久久婷婷五月综合| 国产精品久久影院| 91美女在线视频| 欧美一区二区成人| 国产自产v一区二区三区c| 熟女av一区二区| 一区二区三区在线视频免费| 国产激情第一页| 久久蜜桃一区二区| www.日本不卡| 宅男噜噜噜66一区二区66| 久久精品国产秦先生| 男人的午夜天堂| 一区二区三区日本| 久久久久久国产精品无码| 国产精品丝袜一区| 性感美女一区二区三区| 精品国产三级a在线观看| 成人午夜精品在线| 欧美一区二区三区精品| 国产精品资源在线看| 欧美日免费三级在线| 蜜桃精品视频在线| 色综合久久88色综合天天6| 亚州成人在线电影| 黄色av片三级三级三级免费看| 亚洲欧美成aⅴ人在线观看| 给我看免费高清在线观看| 中文字幕巨乱亚洲| 久久久高清视频| 中文字幕精品一区二区精品绿巨人 | 亚洲精品国产精华液| 极品粉嫩小仙女高潮喷水久久| 欧美国产精品专区| 99久久久无码国产精品性波多 | 精品国产伦一区二区三区观看体验 | 欧美视频一区二区三区四区 | 日韩亚洲欧美成人一区| 国产69精品久久99不卡| 91精品国产综合久久蜜臀| 国产999精品久久久久久| 欧美一级生活片| 成人av小说网| 精品人在线二区三区| 91美女片黄在线观看91美女| 2023国产精品| 国产精品果冻传媒| 中文字幕亚洲一区二区va在线| 精品人妻一区二区三区日产乱码卜| 中文字幕一区二区三区四区 | 精品人妻一区二区三区香蕉| 波多野结衣福利| 亚洲丝袜另类动漫二区| 谁有免费的黄色网址| 亚洲国产中文字幕| 免费看一级大片| 久久精品国内一区二区三区| 欧美日韩精品综合在线| 国产.欧美.日韩| 精品国产免费视频| 97中文字幕在线观看| 国产精品久久久久精k8| 午夜精产品一区二区在线观看的| 亚洲18色成人| 欧美这里有精品| 北条麻妃国产九九精品视频| 精品福利二区三区| 伊人av在线播放| 亚洲欧洲精品天堂一级| 日本黄色激情视频| 麻豆91在线观看| 欧美一二三区精品| 在线成人精品视频| 亚洲欧美日韩电影| 麻豆视频在线免费看| 国产麻豆成人传媒免费观看| 日韩精品一区二| 成人手机在线免费视频| 亚洲小说欧美激情另类| 在线观看av一区| 99热国产精品| 自拍偷拍欧美激情| 日韩一区二区三区四区在线| 国产二区国产一区在线观看| 国产亚洲精品精华液| 久久午夜福利电影| 精品影视av免费| 久久婷婷国产综合国色天香 | 亚洲成人黄色影院| 欧美亚洲愉拍一区二区| 91免费在线播放| 一区二区三区在线观看网站| 色婷婷久久99综合精品jk白丝| 成a人片国产精品| 亚洲欧美另类图片小说| 日本久久一区二区三区| 99精品久久久久久| 有码一区二区三区| 欧美日韩一区视频| 日韩Av无码精品| 丝袜美腿亚洲一区| 日韩欧美国产系列| 青娱乐国产视频| 国产麻豆精品theporn| 国产精品视频你懂的| 男女做暖暖视频| 97久久超碰精品国产| 亚洲激情成人在线| 欧美日韩一级黄| 88av在线播放| 理论片日本一区| 国产偷国产偷亚洲高清人白洁| 国产免费一区二区三区四区| 成人午夜电影久久影院| 亚洲精品成人悠悠色影视| 欧美区在线观看| 可以直接看的无码av| 狠狠色伊人亚洲综合成人| 国产精品丝袜91| 色国产综合视频| 95视频在线观看| 激情图区综合网| 亚洲欧洲日韩av| 欧美久久婷婷综合色| 熟女俱乐部一区二区| 国产乱码精品一区二区三区五月婷 | 亚洲欧洲性图库| 欧美日韩精品高清| 超碰97人人干| 国产不卡高清在线观看视频| 成人免费在线观看入口| 欧美剧在线免费观看网站| 无码人妻aⅴ一区二区三区69岛| 国产69精品久久久久毛片| 一区二区三区毛片| 精品免费视频.| 黑鬼狂亚洲人videos| 韩国av中国字幕| 国产做a爰片久久毛片| 亚洲人成在线播放网站岛国| 欧美一区二区三区在线观看视频| 日本爱爱爱视频| 91美女蜜桃在线| 六月婷婷色综合| 日韩毛片一二三区| 欧美一级电影网站| 快灬快灬一下爽蜜桃在线观看| 91丨九色丨尤物| 美女在线一区二区| 136国产福利精品导航| 日韩欧美另类在线| 搜索黄色一级片| 日本丰满少妇裸体自慰| 国产91精品久久久久久久网曝门| 性感美女极品91精品| 亚洲国产精品成人综合| 91精品国产综合久久婷婷香蕉| 久久国产波多野结衣| 超碰97在线资源站| 成人av资源站| 精品一区二区三区免费播放| 一区二区三区色| 国产女同互慰高潮91漫画| 欧美一区二区三区影视| 国产va在线播放| x88av在线|