Go(3[切片])
切片:
切片底层都是数组
切片是一个指针类型,是数组的引用!
修改切片后的值,那原来的数据也会改变
传输数据大的时候,使用切片,节省内存,因为底层只是对数组的引用
append操作的适合,如果长度超过设置的长度,那底层就会把底层元组进行扩容
切片里面可以放任何类型!!!
切片初始化:
var b[]int = []int{1,2,3,4,5}
切片底层都是数组
切片是一个指针类型,应用类型,是数组的引用!!!
修改切片后的值,那原来的数据也会改变
如果传输的内容过大,介意用切片,节省内存
切片定义(代码):
切片是数组的引用,所以先创建一个数组
var a [5]int
var b[]int = a[0:2] b是切片
伪代码定义:
a[start:end]
示例
示例一: 循环数组
时刻记住go是强类型语言,变量后面需要指定类型
funcSum(a[100]int)int{c:=0fori:=0;i<len(a);i++{c+=a[i]}returnc}
示例二:循环切片
其实与循环数组方式一样
需要注意是传参的时候,需要把数组转化为切片
var c[1000] int 转化为切片就是 c[:]
funcSum2(a[]int)int{c:=0fori:=0;i<len(a);i++{c+=a[i]}returnc}
字符串切片:
//一个bytes占一个字节一个字节是8位//一个字符--》有可能占一个字节,或者三个字节//一个中文,占3个字节
字符串底层是bytes的切片, 是用指针指向utf-8字节数组!!
字符串是只读的!!,所以需要把字符串转切片,然后在修改字符串,那就相当于开辟一块新的内存空间
修改字符串,可将其转化成【】rune或[]bytes ,完成后在转化为string ,无论哪种方式,都会重新分配内存,并复制字节数组
varstr="helloword"//把字符串转切片,然后在修改字符串str1:=str[:]fmt.Printf("%s\n",str1)//单引号是代表一个字符varb[]byte=[]byte(str)//通过下标重新赋值b[0]='a'str2:=string(b)fmt.Println(str2,len(b))
示例一:
functestRever(){//英文反转varstr="helloword"varb[]byte=[]byte(str)fori:=0;i<len(b)/2;i++{b[i]=b[len(b)-i-1]b[len(b)-i-1]=b[i]}str2:=string(b)fmt.Println(str2,len(b))}
实例二:
中文操作:rune
functestChina(){//带中文的反转str:="Hi我爱晨红"//rune可能占一个字节或者多个字节b:=[]rune(str)fmt.Println("testChina",len(str),len(b))fori:=0;i<len(b)/2;i++{b[i],b[len(b)-i-1]=b[len(b)-i-1],b[i]}str2:=string(b)fmt.Println("testChina",str2)}
functestConetChine(){//统计中文,和英文出现的次数str:="翟hello,worker"b:=[]rune(str)fmt.Println("testChina",len(str),len(b))}>>>>testChina1713
得出!!当统计类型为字符串的适合,它会把每个值都当成一个字节来统计
转换rune后,那统计rune后的值,长度就变化了
实例三:
functestConetChine(){//统计中文,和英文出现的次数str:="哈哈哈哈测试,hello,worker"b:=[]rune(str)fmt.Println("testChina",len(b),len(str))}
切片的创建:
第一种定义方式:定义切片的时候.默认是空 nil
vara[]inta=append(a,1,2,3,7,8)fmt.Printf("%#v\n",a)
第二种定义方式:用make的时候,切片内容默认都是0,底层是有数据的
a=make([]int,5)a=append(a,1,2,3,7,8)fmt.Printf("%#v\n",a)
切片只能用make来创建
底层还是数组,是make来创建的
//容量扩容原理
示例:
functestSliceCap(){//a切片长度为5,容量为10,那底层数组长度就是10//那b可以在a的基础上扩容,但是不能超容量10a:=make([]int,5,10)a[4]=100//容量是从1开始,所以现在b:=a[1:3]的容量是9b:=a[1:3]//b[9]=100fmt.Printf("a=%#v\n",a)fmt.Printf("b=%#v\n",b)//cap内置方法求出切片的容量7fmt.Println(cap(a),cap(b))}
切片Copy:
copy(目标切片,源切片)
打印内存地址参数:p
cap 切片容量
s1:=[]int{1,2,3}s2:=make([]int,10)copy(s2,s1)fmt.Println("\n",s1)fmt.Println("\n",s2,cap(s2))>------[123][1230000000]10
切片Append:
定义切片: s3 :=[]int{1,2,3}
s4:=append(s3,3,4,5,6)
数组 / 切片 中的 ... 使用
数组:
functestArray(){vara[5]int=[5]int{1,3}fmt.Println(a)//数组的...是系统内部帮你计算,当你不知道有多少个的时候,那就用...varc=[...]int{1,3,4}fmt.Println(c)}
切片:
2个切片的append
//... 就是展开切片的意思
a=make([]int,5)varb[]=[]int{1,3,6,10}a=append(a,b...)
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。