golang:计算字符串长度一一len()和RuneCountInString()

分手后的思念是犯贱 2022-09-07 06:25 240阅读 0赞

golang的内建函数len(),可以用来获取切片、字符串、通道(channel)等的长度。下面的代码可以用 len() 来获取字符串的长度。

  1. tip1 := "genji is a ninja"
  2. fmt.Println(len(tip1))
  3. tip2 := "忍者"
  4. fmt.Println(len(tip2))

程序输出如下:

  1. 16
  2. 6

len() 函数的返回值的类型为 int,表示字符串的 ASCII 字符个数或字节长度。

  • 输出中第一行的 16 表示 tip1 的字符个数为 16。
  • 输出中第二行的 6 表示 tip2 的字符格式,也就是“忍者”的字符个数是 6,然而根据习惯,“忍者”的字符个数应该是 2。

这里的差异是由于golang的字符串都是以UTF-8格式保存,每个中文占用3个字节,因此使用 len() 获得两个中文文字对应的 6 个字节。

如果希望按习惯上的字符个数来计算,就需要使用 Go 语言中 UTF-8 包提供的 RuneCountInString() 函数,统计 Uncode 字符数量。

下面的代码展示如何计算UTF-8的字符个数。

  1. fmt.Println(utf8.RuneCountInString("忍者"))
  2. fmt.Println(utf8.RuneCountInString("龙忍出鞘,fight!"))

程序输出如下:

  1. 2
  2. 11

一般游戏中在登录时都需要输入名字,而名字一般有长度限制。考虑到国人习惯使用中文做名字,就需要检测字符串 UTF-8 格式的长度。

总结

  • ASCII 字符串长度使用 len() 函数。
  • Unicode 字符串长度使用 utf8.RuneCountInString() 函数。

发表评论

表情:
评论列表 (有 0 条评论,240人围观)

还没有评论,来说两句吧...

相关阅读