日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷(xiāo)解決方案
創(chuàng)新互聯(lián)GO教程:Go語(yǔ)言字符類(lèi)型(byte和rune)

字符串中的每一個(gè)元素叫做“字符”,在遍歷或者單個(gè)獲取字符串元素時(shí)可以獲得字符。

Go語(yǔ)言的字符有以下兩種:

  • 一種是 uint8 類(lèi)型,或者叫 byte 型,代表了 ASCII 碼的一個(gè)字符。
  • 另一種是 rune 類(lèi)型,代表一個(gè) UTF-8 字符,當(dāng)需要處理中文、日文或者其他復(fù)合字符時(shí),則需要用到 rune 類(lèi)型。rune 類(lèi)型等價(jià)于 int32 類(lèi)型。

byte 類(lèi)型是 uint8 的別名,對(duì)于只占用 1 個(gè)字節(jié)的傳統(tǒng) ASCII 編碼的字符來(lái)說(shuō),完全沒(méi)有問(wèn)題,例如 var ch byte = 'A',字符使用單引號(hào)括起來(lái)。

在 ASCII 碼表中,A 的值是 65,使用 16 進(jìn)制表示則為 41,所以下面的寫(xiě)法是等效的:

var ch byte = 65 或 var ch byte = '\x41'      //(\x 總是緊跟著長(zhǎng)度為 2 的 16 進(jìn)制數(shù))

另外一種可能的寫(xiě)法是
\后面緊跟著長(zhǎng)度為 3 的八進(jìn)制數(shù),例如 \377。

Go語(yǔ)言同樣支持 Unicode(UTF-8),因此字符同樣稱為 Unicode 代碼點(diǎn)或者 runes,并在內(nèi)存中使用 int 來(lái)表示。在文檔中,一般使用格式 U+hhhh 來(lái)表示,其中 h 表示一個(gè) 16 進(jìn)制數(shù)。

在書(shū)寫(xiě) Unicode 字符時(shí),需要在 16 進(jìn)制數(shù)之前加上前綴
\u或者
\U。因?yàn)?Unicode 至少占用 2 個(gè)字節(jié),所以我們使用 int16 或者 int 類(lèi)型來(lái)表示。如果需要使用到 4 字節(jié),則使用
\u前綴,如果需要使用到 8 個(gè)字節(jié),則使用
\U前綴。

var ch int = '\u0041'
var ch2 int = '\u03B2'
var ch3 int = '\U00101234'
fmt.Printf("%d - %d - %d\n", ch, ch2, ch3) // integer
fmt.Printf("%c - %c - %c\n", ch, ch2, ch3) // character
fmt.Printf("%X - %X - %X\n", ch, ch2, ch3) // UTF-8 bytes
fmt.Printf("%U - %U - %U", ch, ch2, ch3)   // UTF-8 code point

輸出:

65 - 946 - 1053236
A - β - r
41 - 3B2 - 101234
U+0041 - U+03B2 - U+101234

格式化說(shuō)明符
%c用于表示字符,當(dāng)和字符配合使用時(shí),
%v
%d會(huì)輸出用于表示該字符的整數(shù),
%U 輸出格式為 U+hhhh 的字符串。

Unicode 包中內(nèi)置了一些用于測(cè)試字符的函數(shù),這些函數(shù)的返回值都是一個(gè)布爾值,如下所示(其中 ch 代表字符):

  • 判斷是否為字母:unicode.IsLetter(ch)
  • 判斷是否為數(shù)字:unicode.IsDigit(ch)
  • 判斷是否為空白符號(hào):unicode.IsSpace(ch)

UTF-8 和 Unicode 有何區(qū)別?

Unicode 與 ASCII 類(lèi)似,都是一種字符集。

字符集為每個(gè)字符分配一個(gè)唯一的 ID,我們使用到的所有字符在 Unicode 字符集中都有一個(gè)唯一的 ID,例如上面例子中的 a 在 Unicode 與 ASCII 中的編碼都是 97。漢字“你”在 Unicode 中的編碼為 20320,在不同國(guó)家的字符集中,字符所對(duì)應(yīng)的 ID 也會(huì)不同。而無(wú)論任何情況下,Unicode 中的字符的 ID 都是不會(huì)變化的。

UTF-8 是編碼規(guī)則,將 Unicode 中字符的 ID 以某種方式進(jìn)行編碼,UTF-8 的是一種變長(zhǎng)編碼規(guī)則,從 1 到 4 個(gè)字節(jié)不等。編碼規(guī)則如下:

  • 0xxxxxx 表示文字符號(hào) 0~127,兼容 ASCII 字符集。
  • 從 128 到 0x10ffff 表示其他字符。

根據(jù)這個(gè)規(guī)則,拉丁文語(yǔ)系的字符編碼一般情況下每個(gè)字符占用一個(gè)字節(jié),而中文每個(gè)字符占用 3 個(gè)字節(jié)。

廣義的 Unicode 指的是一個(gè)標(biāo)準(zhǔn),它定義了字符集及編碼規(guī)則,即 Unicode 字符集和 UTF-8、UTF-16 編碼等。


網(wǎng)站名稱:創(chuàng)新互聯(lián)GO教程:Go語(yǔ)言字符類(lèi)型(byte和rune)
當(dāng)前網(wǎng)址:http://www.5511xx.com/article/cddjecg.html