字符,字节(byte重点)
// 字符串
s := "hello 皇甫村"
// 单独的字母,汉字,符号表示一个字符
c1 := 'h'
c2 := '皇'
// 字节。一个字节=8bit(8个二进制位)
// 一个'A' =1一个字节
// 一个utf8编码的汉字 '砂' = 一般占用3个字节
1kb = 1024字节
字符串
package main
import (
"fmt"
"strings"
)
// 字符串相关操作
var s3 = "C:\\Windows\\SoftwareDistribution\\Download"
func main() {
// 字符串长度
fmt.Println(len(s3))
// 字符串拼接
name := "理想"
world := "dsb"
fmt.Println(name + world) // 直接打印到终端
ss := fmt.Sprintf("%s%s", name, world) // 直接返回了,需要一个变量来接收
fmt.Println(ss)
// 字符串分割
ret := strings.Split(s3, "\\") // 需要用到strings这个包
fmt.Println(ret)
// 拼接
joins := strings.Join(ret, "+")
fmt.Println(joins)
// 包含
fmt.Println(strings.Contains(ss, "理性"))
results := strings.Contains(ss, "理想")
fmt.Println(results)
// 前缀和后缀,也就是以什么开头,以什么结尾,在python中相当于 startswith,endswith
fmt.Println("前缀和后缀,也就是以什么开头,以什么结尾,在python中相当于 startswith,endswith")
fmt.Println(strings.HasPrefix(ss, "理想"))
rest := strings.HasPrefix(ss, "理想")
fmt.Println(rest)
fmt.Println(strings.HasSuffix(ss, "理想"))
rest2 := strings.HasSuffix(ss, "理想")
fmt.Println(rest2)
// 判断出现的位置,返回索引值,索引也是从0开始的,跟python没差
// Index 返回子串 sep 在字符串 s 中第一次出现的位置
// 如果找不到,则返回 -1,如果 sep 为空,则返回 0。
s4 := "abcded"
ind := strings.Index(s4, "c") // 不能用单引号,cannot use 'c' (type rune) as type string in argument to strings.Index
fmt.Println(ind) //2
// LastIndex 返回子串 sep 在字符串 s 中最后一次出现的位置
// 如果找不到,则返回 -1,如果 sep 为空,则返回字符串的长度
// 使用朴素字符串比较算法实现
lastind := strings.LastIndex(s4, "c")
fmt.Println(lastind) //2
}
string类型
字符串就是一串固定长度的字符连接起来的字符序列。
Go 的字符串是由单个字节连接起来的。
Go 语言的字符串的字节使用 UTF-8 编码标识 Unicode 文本
注意事项
1. Go语言的字符串的字节使用UTF-8编码标识Unicode文本,
这样Golang统一使用UTF-8编码,中文 乱码问题不会再困扰程序员。
2. 字符串一旦赋值了,字符串就不能修改了:在 Go 中字符串是不可变的。address[0] = 's' 会报错
3. 字符串的两种表示形式
3.1 双引号, 会识别转义字符
3.2 反引号,以字符串的原生形式输出,包括换行和特殊字符,可以实现防止攻击、输出源代码等效果
4. 字符串拼接方式
5. 当一行字符串太长时,需要使用到多行字符串,可以如下处理
str5 := "adadas" + "adsadasdd" +
"sdfsfsdf" + "dfdfsdf" +
"dsfsfsdf"