golang byte是什么


本文摘自php中文网,作者(*-*)浩,侵删。

字符串中的每一个元素叫做“字符”,在遍历或者单个获取字符串元素时可以获得字符。

Go语言的字符有以下两种:

一种是 uint8 类型,或者叫 byte 型,代表了 ASCII 码的一个字符。 (推荐学习:go)

另一种是 rune 类型,代表一个 UTF-8 字符,当需要处理中文、日文或者其他复合字符时,则需要用到 rune 类型。rune 类型等价于 int32 类型。

byte 类型是 uint8 的别名,对于只占用 1 个字节的传统 ASCII 编码的字符来说,完全没有问题,例如 var ch byte = 'A',字符使用单引号括起来。

在 ASCII 码表中,A 的值是 65,使用 16 进制表示则为 41,所以下面的写法是等效的:

1

var ch byte = 65 或 var ch byte = '\x41'      //(\x 总是紧跟着长度为 2 的 16 进制数)

另外一种可能的写法是\后面紧跟着长度为 3 的八进制数,例如 \377。

Go语言同样支持 Unicode(UTF-8),因此字符同样称为 Unicode 代码点或者 runes,并在内存中使用 int 来表示。在文档中,一般使用格式 U+hhhh 来表示,其中 h 表示一个 16 进制数。

在书写 Unicode 字符时,需要在 16 进制数之前加上前缀\u或者\U。因为 Unicode 至少占用 2 个字节,所以我们使用 int16 或者 int 类型来表示。如果需要使用到 4 字节,则使用\u前缀,如果需要使用到 8 个字节,则使用\U前缀。

1

2

3

4

5

6

7

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

输出:

1

2

3

4

65 - 946 - 1053236

A - β - r

41 - 3B2 - 101234

U+0041 - U+03B2 - U+101234

格式化说明符%c用于表示字符,当和字符配合使用时,%v或%d会输出用于表示该字符的整数,%U输出格式为 U+hhhh 的字符串。

Unicode 包中内置了一些用于测试字符的函数,这些函数的返回值都是一个布尔值,如下所示(其中 ch 代表字符):

1

2

3

判断是否为字母:unicode.IsLetter(ch)

判断是否为数字:unicode.IsDigit(ch)

判断是否为空白符号:unicode.IsSpace(ch)

以上就是golang byte是什么的详细内容,更多文章请关注木庄网络博客!!

相关阅读 >>

一文搞懂如何实现 go 超时控制

[go]使用go-smtp发送邮件通知

go的值类型和引用类型2——内存分配规则

基于原论文,我实现了一个更全面的布谷鸟过滤器

golang-2(变量)

golang 如何结束一个协程

大型迷惑现场之[]*t是什么?*[]t是什么?*[]*t又是什么?

手撸golang go与微服务 聚合模式之2

golang学习笔记--unsafe.pointer和uintptr

案例分享:基于golang的支付宝支付

更多相关阅读请进入《golang》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...