为了账号安全,请及时绑定邮箱和手机立即绑定

Go 快速入门指南 - 字符切片

标签:
Go

概述

建议先阅读 字符串, 切片 两个小节。

由于字符串不可变,如果每次以 重新赋值 的方式改变字符串,效率会非常低,这时应该使用 []byte 类型,[]byte 元素可以被修改。

因为 byte 类型是 uint8 类型的别名,所以 []byte 也就是 []uint8

语法规则

字符串转化为 []byte

package main

import "fmt"

func main() {
    s := "hello world"
    b := []byte(s)
    fmt.Printf("b type = %T, val = %s\n", b, b)
}

// $ go run main.go
// 输出如下
/**
  b type = []uint8, val = hello world
*/

[]byte 转换为字符串

package main

import "fmt"

func main() {
    b := []byte{'h', 'e', 'l', 'l', '0', ' ', 'w', 'o', 'r', 'l', 'd'}
    s := string(b)
    fmt.Printf("s type = %T, val = %s\n", s, s)
}

// $ go run main.go
// 输出如下
/**
  s type = string, val = hell0 world
*/

长度计算

关于字符串不同编码对长度的计算方式,感兴趣的读者可以参考扩展阅读。

ASCII

package main

import "fmt"

func main() {
    b := []byte{'h', 'i'}
    fmt.Printf("b length = %d\n", len(b))
}

// $ go run main.go
// 输出如下
/**
  b length = 2
*/

中文算作 3 个字符

package main

import "fmt"

func main() {
    b := []byte("我是")
    fmt.Printf("b length = %d\n", len(b))
}

// $ go run main.go
// 输出如下
/**
  b length = 6
*/

中文算作 1 个字符

package main

import (
    "fmt"
    "unicode/utf8"
)

func main() {
    b := []byte("我是")
    fmt.Printf("b length = %d\n", utf8.RuneCount(b))
}

// $ go run main.go
// 输出如下
/**
  b length = 2
*/

扩展阅读

    1. 十分钟搞清字符集和字符编码 (http://cenalulu.github.io/linux/character-encoding/)
点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
全栈工程师
手记
粉丝
0
获赞与收藏
0

关注作者,订阅最新文章

阅读免费教程

  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消