Go语言的字符串
Go语言的字符有两种:
uint8类型,或者叫 byte 型,字符串中的每个元素代表了ASCII码的一个字符
rune类型,代表一个 UTF-8字符。
可以看到string
类型中的字符默认为uint8
类型,也就是byte
类型
再看看字符串长度和实际值:
str
中字符串长度和实际输出的长度一致
str2
中,输出的长度是12,而实际是包含8个字符,根据utf8编码可知,"你"的编码是E4BDA0
,"好"的编码是E5A5BD
,各占用3个字节,所以这就是为什么输出长度是12了
再看str2
的第一个字符为什么是ä
,你的编码是E4BDA0
,第一个字节是4E
,参照ASCII码对照表可知,4E
对应的字符就是ä
从上面可以看出,当我们处理多字节的字符时,得到的并不是我们想要的结果,这个时候就需要用到 rune
类型来处理中、日文等其他复合字符
需要将string
类型的字符串转换成[]rune
数组类型,这样便能正确的处理复合字符,因为rune
类型是用utf8
编码的;需要注意的是for range
遍历字符串是,会先将字符串转成[]rune
数组类型,然后再进行遍历
Go用这两种方式处理字符串可能相对来说性能有所提升,但似乎会引起过度底层和复杂的代码。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具