Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
_Fighter
Learngo
提交
8ada7d06
L
Learngo
项目概览
_Fighter
/
Learngo
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
11
Wiki
分析
仓库
DevOps
项目成员
Pages
L
Learngo
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
11
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
8ada7d06
编写于
12月 13, 2021
作者:
_Fighter
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
2021年12月10日
上级
eebfd979
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
44 addition
and
0 deletion
+44
-0
strings.go
strings.go
+44
-0
未找到文件。
strings.go
0 → 100644
浏览文件 @
8ada7d06
package
main
import
(
"fmt"
"unicode/utf8"
)
/*
rune 相当于go的char
使用range遍历 pos ,rune 对
使用utn8.RuneCountInString 获得字符数量
使用len 获得字节长度
使用[]byte 获得字节
*/
func
main
()
{
s
:=
"love中国!"
//UTF-8 一个字占三个字节 ,英文一字节
fmt
.
Println
(
s
)
for
_
,
b
:=
range
[]
byte
(
s
)
{
fmt
.
Printf
(
"%X "
,
b
)
}
fmt
.
Println
()
// 以下把s 对utf8 进行解码,转换成unicode ,之后赋值给 rune
for
i
,
ch
:=
range
s
{
// ch is a rune(四字节)
fmt
.
Printf
(
" (%d %X) "
,
i
,
ch
)
}
fmt
.
Println
()
fmt
.
Println
(
" Rune Count:"
,
utf8
.
RuneCountInString
(
s
))
bytes
:=
[]
byte
(
s
)
for
len
(
bytes
)
>
0
{
ch
,
size
:=
utf8
.
DecodeRune
(
bytes
)
bytes
=
bytes
[
size
:
]
fmt
.
Printf
(
"%c "
,
ch
)
}
fmt
.
Println
()
for
i
,
ch
:=
range
[]
rune
(
s
)
{
// ch is a rune(四字节)
fmt
.
Printf
(
" (%d %c) "
,
i
,
ch
)
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录