标签:字符串类 换行 ext 返回 无法 多个 lis pack 包括
目录
int8、int16、int32、int64
,后面的数字表示二进制时的长度
uint8
就是我们熟知的byte
型,int16
对应C语言中的short
型,int64
对应C语言中的long
型。例子: int8
范围是 (-128 到 127) 的整数,负数比正数多一个
uint8、uint16、uint32、uint64
例子:uint8
范围是 (0 到 255) 的整数
uint
: 32位操作系统上就是uint32
,64位操作系统上就是uint64
int
: 32位操作系统上就是int32
,64位操作系统上就是int64
uintptr
: 无符号整型,用于存放一个指针int
和 uint
类型时,不能假定它是32位或64位的整型,而是考虑int
和uint
可能在不同平台上的差异。Go1.13版本之后引入了数字字面量语法 , 这样便于开发者以二进制、八进制或十六进制浮点数的格式定义数字 。共四种表示。
实例
1. v := 0b00101101, 代表二进制的 101101,相当于十进制的 45
2. v := 0o377,代表八进制的 377,相当于十进制的 255
3. v := 0x1p-2,代表十六进制的 1 除以 22,也就是 0.25
4. v := 123_456 等于 123456
Go语言支持两种浮点型数:float32
和float64
打印浮点数时,可以使用fmt
包配合动词%f
,代码如下:
package main
import (
"fmt"
"math"
)
func main() {
fmt.Printf("%f\n", math.Pi)
fmt.Printf("%.2f\n", math.Pi)
}
分为complex64
和complex128
实例
var c1 complex64
c1 = 1 + 2i
var c2 complex128
c2 = 2 + 3i
fmt.Println(c1)
fmt.Println(c2)
复数有实部和虚部,complex64
的实部和虚部为32位,complex128
的实部和虚部为64位
同其他语言一样,就是两个布尔值true
和false
false
UTF-8
编码转义符 | 解释 |
---|---|
\r |
回车符(返回首行) |
\n |
换行符(跳到下一行的同列位置) |
\t |
制表符 |
\‘ |
单引号 |
\" |
双引号 |
\\ |
反斜杠 |
用反引号引住即可
//单行字符串
s1 := "字符串内容"
//多行字符串
s1 := `第一行
第二行
第三行
`
反引号间换行将被作为字符串中的换行,但是所有的转义字符均无效,文本将会原样输出。
方法 | 介绍 |
---|---|
len(str) |
求长度 |
+或fmt.Sprintf |
拼接字符串 |
strings.Split |
分割 |
strings.contains |
判断是否包含 |
strings.HasPrefix,strings.HasSuffix |
前缀/后缀判断 |
strings.Index(),strings.LastIndex() |
子串出现的位置 |
strings.Join(a[]string, sep string) |
join操作 |
byte
和 rune
类型Go 语言的字符有两种 :即byte 和 rune
类型
字符使用单引号包裹起来
实例
var a := '中'
var b := 'x'
byte
uint8
类型,或者叫 byte 型,代表了ASCII码
的一个字符
Go 使用了特殊的 rune 类型来处理 Unicode,让基于 Unicode 的文本处理更为方便,也可以使用 byte 型进行默认字符串处理,性能和扩展性都有照顾
rune
rune
类型,代表一个 UTF-8字符
当需要处理中文、日文或者其他复合字符时,则需要用到rune
类型。rune
类型实际是一个int32
byte
和rune
的对比)Go 使用了特殊的 rune 类型来处理 Unicode,让基于 Unicode 的文本处理更为方便,也可以使用 byte 型进行默认字符串处理,性能和扩展性都有照顾
实例
// 遍历字符串
func traversalString() {
s := "hello沙河"
for i := 0; i < len(s); i++ { //byte
fmt.Printf("%v(%c) ", s[i], s[i])
}
fmt.Println()
for _, r := range s { //rune
fmt.Printf("%v(%c) ", r, r)
}
fmt.Println()
}
打印结果:
// 104(h) 101(e) 108(l) 108(l) 111(o) 230(?) 178(2) 153() 230(?) 178(2) 179(3)
// 104(h) 101(e) 108(l) 108(l) 111(o) 27801(沙) 27827(河)
因为UTF8编码下一个中文汉字由3~4个字节组成,所以我们不能简单的按照字节去遍历一个包含中文的字符串,否则就会出现上面实例中输出中第一行的结果
[]
byte`类型。rune类型用来表示utf8字符,一个rune字符由一个或多个byte组成
要修改字符串,需要先将其转换成[]rune
或[]byte
,完成后再转换为string
。无论哪种转换,都会重新分配内存,并复制字节数组
实例
func changeString() {
s1 := "big"
// 强制类型转换
byteS1 := []byte(s1)
byteS1[0] = 'p'
fmt.Println(string(byteS1)) // "pig"
s2 := "白萝卜"
runeS2 := []rune(s2)
runeS2[0] = '红'
fmt.Println(string(runeS2)) // "红萝卜"
}
Go语言中只有强制类型转换,没有隐式类型转换。该语法只能在两个类型之间支持相互转换的时候使用
强制类型转换的基本语法
T(表达式)
// T表示要转换的类型 ,表达式包括变量、复杂算子和函数返回值等.
强制类型转换实例
func sqrtDemo() {
var a, b = 3, 4
var c int
// math.Sqrt()接收的参数是float64类型,需要强制转换
c = int(math.Sqrt(float64(a*a + b*b)))
fmt.Println(c)
}
标签:字符串类 换行 ext 返回 无法 多个 lis pack 包括
原文地址:https://www.cnblogs.com/Mcoming/p/11967309.html