扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
今天小编给大家分享一下go语言中字符串如何遍历的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。
创新互联是一家网站设计公司,集创意、互联网应用、软件技术为一体的创意网站建设服务商,主营产品:成都响应式网站建设、品牌网站制作、全网营销推广。我们专注企业品牌在网站中的整体树立,网络互动的体验,以及在手机等移动端的优质呈现。做网站、成都做网站、移动互联产品、网络运营、VI设计、云产品.运维为核心业务。为用户提供一站式解决方案,我们深知市场的竞争激烈,认真对待每位客户,为客户提供赏析悦目的作品,网站的价值服务。
字符串遍历方法:1、使用“for range”语句遍历,语法“for key, value := range str {...}”;2、使用strings包的Map()函数来遍历,语法“trings.Map(func(rune), 原字符串)”,其中参数“func(rune)”是一个回调函数,用于对字符串中每一个字符进行处理。
go语言中遍历字符串的方法
方法1:使用for range语句
for range 结构是Go语言特有的一种的迭代结构,在许多情况下都非常有用,for range 可以遍历数组、切片、字符串、map 及通道(channel),for range 语法上类似于其它语言中的 foreach 语句,一般形式为:
for key, val := range coll {
...
}
需要要注意的是,val 始终为集合中对应索引的值拷贝,因此它一般只具有只读性质,对它所做的任何修改都不会影响到集合中原有的值。一个字符串是 Unicode 编码的字符(或称之为 rune )集合,因此也可以用它来迭代字符串:
for pos, char := range str {
...
}
每个 rune 字符和索引在 for range 循环中是一一对应的,它能够自动根据 UTF-8 规则识别 Unicode 编码的字符。
下面这段代码展示了如何遍历字符串:
package main
import (
"fmt"
)
func main() {
var str = "hello 你好"
for key, value := range str {
fmt.Printf("key:%d value:0x%x\n", key, value)
}
}
代码输出如下:
代码中的变量 value,实际类型是 rune 类型,以十六进制打印出来就是字符的编码。
方法2:使用strings.Map() 函数
在开发过程中,很多时候我们需要对一个 字符串 中的每一个 字符 都做相对应的处理,在 Go 语言 中,提供了 strings.Map() 函数 实现了这样的功能。
func Map(mapping func(rune) rune, s string) string
参数 | 描述 |
---|---|
mapping | 对字符串中每一个字符的处理函数。 |
s | 原字符串。 |
返回值:
返回处理后的字符串。
说明:
对字符串 s 中的每一个字符都做 mapping 处理。mapping 是一个 匿名函数 ,接受一个 rune 类型的参数,返回的也是一个 rune 类型的参数。
示例1:遍历字符串,将字符串每一个字符后移一位
package main
import (
"fmt"
"strings"
)
func strEncry(r rune)rune{
return r+1
}
func main() {
//使用 strings.Map() 函数,实现将一个字符串中的每一个字符都后移一位
strHaiCoder := "HaiCoder"
mapStr := strings.Map(strEncry, strHaiCoder)
fmt.Println("mapStr =", mapStr)
}
分析:
我们定义了一个字符串类型的 变量 strHaicoder,接着我们使用字符串的 strings.Map() 函数将字符串每一位字符使用 strEncry 函数进行处理,并使用 print 打印最终的结果。
strEncry 函数实现了将字符的 ASCII 码加一的功能,即字符往后移动一位,因此我们传入的字符串是 “HaiCoder”,最终变成了 “IbjDpefs”。
以上就是“go语言中字符串如何遍历”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注创新互联行业资讯频道。
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流