首页 > 编程知识 正文

golang slice,golang是什么

时间:2023-05-04 21:17:49 阅读:157326 作者:2083

本文介绍了Golang slice切片操作的切片的添加、删除、插入等,共享如下。

一.一般操作

1、声明变量,go自动初始化为nil,长度: 0,地址: 0,nil

func main () }

var ss []string;

fmt.printf (length : % v (taddr : % p ) tis nil : % v (len ) ss ),ss,ss==nil ) ) ) ) )

}

---

运行宁.

length :0 addr 33600 x0is nil :真

success :处理器加密代码0。

2、片的添加、删除、插入操作

func main () }

var ss []string;

fmt.printf ([ local print ]t : (t length : % v (taddr 3360 % p (tis nil : % v (n (,len ) ss,ss,

打印(func print,ss ) )。

//在切片的末尾添加元素append elemnt

for i:=0; i10; i {

ss=append(ss,FMT.sprintf ) s%d ',I );

}

fmt.printf ([ local print ]t : (t length : % v (taddr 3360 % p (tis nil : % v (n (,len ) ss,ss,

打印(after append,ss ) ) )。

//删除切片元素remove element at index

索引:=5;

ss=append(ss[:index],ss[index 1:] . )

print(afterdelete,ss ) ) ) ) ) ) ) ) )。

//在切片中间插入元素insert element at index;

//注意:要保存后部的剩馀元素,必须创建新的临时切片

rear:=append([]string{},ss[index:] . )

ss=append(ss[0:index],' inserted ' )

ss=append(ss,rear . ) )。

打印(after insert,ss ) ) ) ) ) )。

}

funcprint(msgstring,ss []string )。

fmt.printf([s](t: ) tlength:%v ) taddr : % p (tis nil : % v (tcontent : % v ),msg,len ) )

fmt.Println () )。

}

---------

运行宁.

[本地打印] : length :0 addr :0 x0is nil : true

[ func print ] : length :0 addr 33600 x0is nil : true content : [ ]

[本地打印] : length :10 addr 33600 xc 208056000 is nil : false

[ after append ] : length :10 addr 33600 xc 208056000 is nil : false content : [ s0 S1 S2 s3s 4s5 S6 S8 S9 ]

[ after delete ] : length :9 addr 33600 xc 208056000 is nil : false content : [ s0 S1 S2 S3 S4 S6 S7 S8 S9 ]

[ after insert ] : length :10 addr 33600 xc 208056000 is nil : false content : [ s0 S1 S2 S3 S4 inserted S6 S7 S8 S9 ]

success :处理器加密代码0。

3、复印件的使用。

在使用副本复制切片之前,请确保目标切片有足够的大小。 注意尺寸而不是容量,或者请看示例:

func main () }

varsa=make([]string,0 );

for i:=0; i10; i {

sa=append(sa,FMT.sprintf ) ' %v ',I ) )

}

varda=make([]string,0,10 );

var cc=0;

cc=copy(da,sa );

FMT.printf(copytoda ) len=%d )t%vn )、len(da )、da ) )

da=make([]string,5 ) )。

cc=copy(da,sa );

fmt.printf (复印)

to da(len=%d)tcopied=%dt%vn",len(da),cc,da)

da = make([]string,10)

cc =copy(da,sa);

fmt.Printf("copy to da(len=%d)tcopied=%dt%vn",len(da),cc,da)

}

---

Running...

copy to da(len=0) []

copy to da(len=5) copied=5 [0 1 2 3 4]

copy to da(len=10) copied=10 [0 1 2 3 4 5 6 7 8 9]

从上面运行结果,明显看出,目标切片大小0,容量10,copy不能复制。目标切片大小小于源切片大小,copy就按照目标切片大小复制,不会报错。

二、初始大小和容量

当我们使用make初始化切片的时候,必须给出size。go语言的书上一般都会告诉我们,当切片有足够大小的时候,append操作是非常快的。但是当给出初始大小后,我们得到的实际上是一个含有这个size数量切片类型的空元素,看例子:

func main(){

var ss=make([]string,10);

ss=append(ss,"last");

print("after append",ss)

}

---

Running...

[ after append ] : length:11 addr:0xc20804c000 isnil:false content:[ last]

实际上,此时我们应该先用下标为切片元素负值。但是如果我们既想有好的效率,有想继续使用append函数而不想区分是否有空的元素,此时就要请出make的第三个参数,容量,也就是我们通过传递给make,0的大小和足够大的容量数值就行了。

func main(){

var ss=make([]string,0,10);

ss=append(ss,"last");

print("after append",ss)

}

---

Running...

[ after append ] : length:1 addr:0xc20804a000 isnil:false content:[last]

三、切片的指针。

1,当我们用append追加元素到切片时,如果容量不够,go就会创建一个新的切片变量,看下面程序的执行结果:

func main() {

var sa []string

fmt.Printf("addr:%p ttlen:%v content:%vn",sa,len(sa),sa);

for i:=0;i<10;i++{

sa=append(sa,fmt.Sprintf("%v",i))

fmt.Printf("addr:%p ttlen:%v content:%vn",sa,len(sa),sa);

}

fmt.Printf("addr:%p ttlen:%v content:%vn",sa,len(sa),sa);

}

---

Running ...

addr:0x0 len:0 content:[]

addr:0x1030e0c8 len:1 content:[0]

addr:0x10328120 len:2 content:[0 1]

addr:0x10322180 len:3 content:[0 1 2]

addr:0x10322180 len:4 content:[0 1 2 3]

addr:0x10342080 len:5 content:[0 1 2 3 4]

addr:0x10342080 len:6 content:[0 1 2 3 4 5]

addr:0x10342080 len:7 content:[0 1 2 3 4 5 6]

addr:0x10342080 len:8 content:[0 1 2 3 4 5 6 7]

addr:0x10324a00 len:9 content:[0 1 2 3 4 5 6 7 8]

addr:0x10324a00 len:10 content:[0 1 2 3 4 5 6 7 8 9]

addr:0x10324a00 len:10 content:[0 1 2 3 4 5 6 7 8 9]

//很明显,切片的地址经过了数次改变。

2,如果,在make初始化切片的时候给出了足够的容量,append操作不会创建新的切片:

func main() {

var sa = make ([]string,0,10);

fmt.Printf("addr:%p ttlen:%v content:%vn",sa,len(sa),sa);

for i:=0;i<10;i++{

sa=append(sa,fmt.Sprintf("%v",i))

fmt.Printf("addr:%p ttlen:%v content:%vn",sa,len(sa),sa);

}

fmt.Printf("addr:%p ttlen:%v content:%vn",sa,len(sa),sa);

}

addr:0x10304140 len:0 content:[]

addr:0x10304140 len:1 content:[0]

addr:0x10304140 len:2 content:[0 1]

addr:0x10304140 len:3 content:[0 1 2]

addr:0x10304140 len:4 content:[0 1 2 3]

addr:0x10304140 len:5 content:[0 1 2 3 4]

addr:0x10304140 len:6 content:[0 1 2 3 4 5]

addr:0x10304140 len:7 content:[0 1 2 3 4 5 6]

addr:0x10304140 len:8 content:[0 1 2 3 4 5 6 7]

addr:0x10304140 len:9 content:[0 1 2 3 4 5 6 7 8]

addr:0x10304140 len:10 content:[0 1 2 3 4 5 6 7 8 9]

addr:0x10304140 len:10 content:[0 1 2 3 4 5 6 7 8 9]

//可见,切片的地址一直保持不变

3, 如果不能准确预估切片的大小,又不想改变变量(如:为了共享数据的改变),这时候就要请出指针来帮忙了,下面程序中,sa就是osa这个切片的指针,我们共享切片数据和操作切片的时候都使用这个切片地址就ok了,其本质上是:append操作亦然会在需要的时候构造新的切片,不过是将地址都保存到了sa中,因此我们通过该指针始终可以访问到真正的数据。

func main() {

var osa = make ([]string,0);

sa:=&osa;

for i:=0;i<10;i++{

*sa=append(*sa,fmt.Sprintf("%v",i))

fmt.Printf("addr of osa:%p,taddr:%p t content:%vn",osa,sa,sa);

}

fmt.Printf("addr of osa:%p,taddr:%p t content:%vn",osa,sa,sa);

}

---

Running...

addr of osa:0xc20800a220, addr:0xc20801e020 content:&[0]

addr of osa:0xc20801e0a0, addr:0xc20801e020 content:&[0 1]

addr of osa:0xc20803e0c0, addr:0xc20801e020 content:&[0 1 2]

addr of osa:0xc20803e0c0, addr:0xc20801e020 content:&[0 1 2 3]

addr of osa:0xc208050080, addr:0xc20801e020 content:&[0 1 2 3 4]

addr of osa:0xc208050080, addr:0xc20801e020 content:&[0 1 2 3 4 5]

addr of osa:0xc208050080, addr:0xc20801e020 content:&[0 1 2 3 4 5 6]

addr of osa:0xc208050080, addr:0xc20801e020 content:&[0 1 2 3 4 5 6 7]

addr of osa:0xc208052000, addr:0xc20801e020 content:&[0 1 2 3 4 5 6 7 8]

addr of osa:0xc208052000, addr:0xc20801e020 content:&[0 1 2 3 4 5 6 7 8 9]

addr of osa:0xc208052000, addr:0xc20801e020 content:&[0 1 2 3 4 5 6 7 8 9]

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。