首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >不能使用unicode字符作为rune

不能使用unicode字符作为rune
EN

Stack Overflow用户
提问于 2016-10-14 17:10:08
回答 2查看 2.2K关注 0票数 2

golang似乎并不支持其符文的所有unicode字符

代码语言:javascript
复制
package main

import "fmt"

func main() {
  standardSuits := []rune{'♠️', '♣️', '♥️', '♦️'}
  fmt.Println(standardSuits)
}

生成以下错误:

代码语言:javascript
复制
./main.go:6: missing '
./main.go:6: invalid identifier character U+FE0F '️'
./main.go:6: syntax error: unexpected ️, expecting comma or }
./main.go:6: missing '
./main.go:6: invalid identifier character U+FE0F '️'
./main.go:6: missing '
./main.go:6: invalid identifier character U+FE0F '️'
./main.go:6: missing '
./main.go:6: invalid identifier character U+FE0F '️'
./main.go:6: missing '
./main.go:6: too many errors

有没有办法绕过这一点,或者我应该接受这个限制,使用其他东西?

EN

回答 2

Stack Overflow用户

发布于 2016-10-14 17:35:02

在我看来,这是一个解析问题。您可以使用unicode点来生成该符文,这应该会产生与使用字符相同的结果。

代码语言:javascript
复制
package main

import "fmt"

func main() {
  standardSuits := []rune{'\u2660', '\u2663', '\u2665', '\u2666', '⌘'}
  fmt.Println(standardSuits)
}

生成

代码语言:javascript
复制
[9824 9827 9829 9830 8984]

游乐场链接:https://play.golang.org/p/jTLsbs7DM1

我添加了额外的第5个符文,以检查来自码点或字符的结果是否相同。看起来是这样的。

编辑:

不知道你的字符有什么问题(没有在十六进制编辑器中查看它们,周围没有),但它们有一些奇怪的地方。

我还通过复制粘贴维基百科上的字符来运行:

代码语言:javascript
复制
package main

import "fmt"

func main() {
  standardSuits := []rune{'♠', '♣', '♥', '♦'}
  fmt.Println(standardSuits)
}

https://play.golang.org/p/CKR0u2_IIB

票数 5
EN

Stack Overflow用户

发布于 2016-10-15 01:55:06

源代码中使用unicode字符串由多个“字符”组成,但有一个字符常量“...”不允许包含长度大于1的字符串。更详细地说:

如果我复制并粘贴您的源代码并打印一个十六进制转储,我可以看到您的源代码中的确切字节:

代码语言:javascript
复制
>>> hexdump -C x.go
00000000  70 61 63 6b 61 67 65 20  6d 61 69 6e 0a 0a 69 6d  |package main..im|
00000010  70 6f 72 74 20 22 66 6d  74 22 0a 0a 66 75 6e 63  |port "fmt"..func|
00000020  20 6d 61 69 6e 28 29 20  7b 0a 20 20 73 74 61 6e  | main() {.  stan|
00000030  64 61 72 64 53 75 69 74  73 20 3a 3d 20 5b 5d 72  |dardSuits := []r|
00000040  75 6e 65 7b 27 e2 99 a0  ef b8 8f 27 2c 20 27 e2  |une{'......', '.|
00000050  99 a3 ef b8 8f 27 2c 20  27 e2 99 a5 ef b8 8f 27  |.....', '......'|
00000060  2c 20 27 e2 99 a6 ef b8  8f 27 7d 0a 20 20 66 6d  |, '......'}.  fm|
00000070  74 2e 50 72 69 6e 74 6c  6e 28 73 74 61 6e 64 61  |t.Println(standa|
00000080  72 64 53 75 69 74 73 29  0a 7d 0a                 |rdSuits).}.|

例如,这表明您的'♠️'是使用十六进制字节e2 99 a0 ef b8 8f编码的。在utf-8编码中,这对应于两个(!)字符\u2660 \uFE0F。通过查看代码,这一点并不明显,因为\uFE0F不是可打印的字符,但是Go会抱怨,因为一个字符常量中有多个字符。相反,使用'♠''\u2660'可以达到预期效果。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40039291

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档