切片

切片是由数组建立的一种方便、灵活且功能强大的包装(Wrapper)。切片本身不拥有任何数据。它们只是对现有数组的引用。

因此切片的类型是引用类型。

一、切片的创建

1、先创建数组,再引用

// 先创建一个数组
var lis [10]int= [10]int{1,2,3,4,5,6,7,8,9,10}
// 创建切片
var sli = lis[:] // 从头到尾全切
fmt.Println(sli) // [1 2 3 4 5 6 7 8 9 10]
fmt.Printf("%T",sli) // []int
// []内没有数字就是切片,有就是数组

2、直接创建切片

var a []int=[]int{1,2,3,4,5}  //切片初始化,类似于数组初始化

二、切片的修改

因为切片是引用类型,它是对数组的引用。所以切片的修改会影响原来的数组,数组的修改也会影响切片。

var lis [10]int= [10]int{1,2,3,4,5,6,7,8,9,10}

var b []int = lis[5:9]  // 索引取值,左开右闭
b[0]=999
lis[6]=888
fmt.Println(b)
fmt.Println(lis) [999 888 8 9]
[1 2 3 4 5 999 888 8 9 10]

三、切片的长度和容量

len() :长度,现在有多少值

cap() :容量,总共能放多少值,为引用的数组长度-切片首位索引

var lis [10]int= [10]int{1,2,3,4,5,6,7,8,9,10}

var b []int = lis[5:9]  

fmt.Println(len(b))  // 4
fmt.Println(cap(b)) // 5 //(10-5)

四、使用make创建切片

用函数make([]T,len,cap)来创建切片类型的变量,就不用先创建数组了。

函数参数分别为:类型,长度和容量。

容量是可选参数, 默认值为切片长度。

make 函数原理为创建一个数组,并返回引用该数组的切片。

var sli []int=make([]int,3,4)
fmt.Println(len(sli)) // 3
fmt.Println(cap(sli)) // 4

五、切片的修改和追加

1、修改

像列表一样用[索引]取值,修改值。

var a []int=make([]int,3,4)
a[0]=999
a[2]=999 //切片用[]修改值,只能取最大长度修改,超出长度的容量不能用[]的方式取值修改 a[3]=100 // 不行!!!会报错

2、追加:append

使用函数 append(slice []T,x ... T)[]T 可以将新元素追加到切片上。它会有一个返回值,是追加后的新的切片,所以需要用一个值来接受一下。

var sli []int=make([]int,3,4)
sli = append(sli,444)
fmt.Println(len(sli)) // 4
fmt.Println(cap(sli)) // 4

如果append函数添加的值,使切片长度超过最大容量,则会创建一个新的底层数组取代原本切片引用的数组。

原切片的元素被复制到这个新数组中,并返回引用这个新数组的切片。

这个新数组的长度是旧切片容量的两倍。而新切片的容量就等于这个新数组的长度。

所以现在新切片的容量是旧切片的两倍。

此时修改新切片的元素就不会影响原数组了。

// make创建的切片的追加
var sli []int=make([]int,3,4)
fmt.Println(len(sli)) // 3
fmt.Println(cap(sli)) // 4 sli = append(sli,444)
fmt.Println(len(sli)) // 4
fmt.Println(cap(sli)) // 4 sli = append(sli,555)
fmt.Println(sli) // [0 0 0 444 555]
fmt.Println(len(sli)) // 5
fmt.Println(cap(sli)) // 8 // 引用数组的切片的追加
var lis [10]int= [10]int{1,2,3,4,5,6,7,8,9,10}
var sli []int = lis[5:9] fmt.Println(lis) // [1 2 3 4 5 6 7 8 9 10]
fmt.Println(sli) // [6 7 8 9]
fmt.Println(len(sli)) // 4
fmt.Println(cap(sli)) // 5 sli = append(sli,444)
sli[2] = 888 // 切片影响原来的数组
fmt.Println(lis) // [1 2 3 4 5 6 7 888 9 444]
fmt.Println(sli) // [6 7 888 9 444]
fmt.Println(len(sli)) // 5
fmt.Println(cap(sli)) // 5 sli = append(sli,555)
sli[1] = 777 // 新的切片不会影响原来的数组了
fmt.Println(lis) // [1 2 3 4 5 6 7 888 9 444]
fmt.Println(sli) // [6 777 888 9 444 555]
fmt.Println(len(sli)) // 6
fmt.Println(cap(sli)) // 10 新切片的容量是旧切片的两倍

六、切片的函数传值

因为切片的类型是引用类型,因此传值后,改变值会影响原来的值。

var a []int=make([]int,4,5)
fmt.Println(a) // [0 0 0 0]
test2(a) // [111 0 0 0]
// [111 0 0 0 555]
fmt.Println(a) // [111 0 0 0] func test2(x []int) {
x[0] = 111 // 修改a变量地址里的值
fmt.Println(x) // [111 0 0 0]
x = append(x,555) // copy的x的长度变化了,产生了新的切片
fmt.Println(x) // [111 0 0 0 555]
}

七、多维切片

一般直接初始化。

var a [][]int=[][]int{{1,2,3},{2,3},{4,5,5,6,7,8,9}}
fmt.Println(a) // [[1 2 3] [2 3] [4 5 5 6 7 8 9]]

八、切片的copy

把一个切片的元素copy到另一个切片上。

用函数copy(dst(目标), src(源))

var a []int=make([]int,4,5)
var b []int =[]int{1,2,3,4,5} fmt.Println(a) // [0 0 0 0]
fmt.Println(b) // [1 2 3 4 5] //把b的数据copy到a上
copy(a,b)
fmt.Println(a) // [1 2 3 4] // 长度有多少就接受多少
fmt.Println(b) // [1 2 3 4 5] --------------------------------------------------
var a []int=make([]int,6,7)
var b []int =[]int{1,2,3,4,5} fmt.Println(a) // [0 0 0 0 0 0]
fmt.Println(b) // [1 2 3 4 5] //把b的数据copy到a上
copy(a,b)
fmt.Println(a) // [1 2 3 4 5 0] // 不足的用默认值补齐
fmt.Println(b) // [1 2 3 4 5]

Go的切片的更多相关文章

  1. ArcGIS 10.0紧凑型切片读写方法

    首先介绍一下ArcGIS10.0的缓存机制: 切片方案 切片方案包括缓存的比例级别.切片尺寸和切片原点.这些属性定义缓存边界的存在位置,在某些客户端中叠加缓存时匹配这些属性十分重要.图像格式和抗锯齿等 ...

  2. 利用Python进行数据分析(5) NumPy基础: ndarray索引和切片

    概念理解 索引即通过一个无符号整数值获取数组里的值. 切片即对数组里某个片段的描述. 一维数组 一维数组的索引 一维数组的索引和Python列表的功能类似: 一维数组的切片 一维数组的切片语法格式为a ...

  3. 充电时间 Go中的数组、切片、map简单示例

    数组是固定长度的,依稀让我想起了VB:切片是动态的:map一般是键值对 package main import ( "fmt" ) func main() { var userna ...

  4. GO语言总结(3)——数组和切片

    上篇博文简单介绍了一下Go语言的基本类型——GO语言总结(2)——基本类型,本篇博文开始介绍Go语言的数组和切片. 一.数组 与其他大多数语言类似,Go语言的数组也是一个元素类型相同的定长的序列. ( ...

  5. [LeetCode] Arithmetic Slices 算数切片

    A sequence of number is called arithmetic if it consists of at least three elements and if the diffe ...

  6. 网络切片在5G中的应用

    SDNLAB君 • 16-11-25 •1509 人围观 5G和网络切片 当5G被广泛提及的时候,网络切片是其中讨论最多的技术.像KT.SK Telecom.China Mobile.DT.KDDI. ...

  7. KRPano资源分析工具使用说明(KRPano XML/JS解密 切片图批量下载 球面图还原 加密混淆JS还原美化)

    软件交流群:571171251(软件免费版本在群内提供) krpano技术交流群:551278936(软件免费版本在群内提供) 最新博客地址:blog.turenlong.com 限时下载地址:htt ...

  8. 使用KRPano资源分析工具强力加密KRPano项目(XML防破解,切片图保护,JS反调试)

    软件交流群:571171251(软件免费版本在群内提供) krpano技术交流群:551278936(软件免费版本在群内提供) 最新博客地址:blog.turenlong.com 限时下载地址:htt ...

  9. 使用KRPano资源分析工具一键下载全景网站切片图

    软件交流群:571171251(软件免费版本在群内提供) krpano技术交流群:551278936(软件免费版本在群内提供) 最新博客地址:blog.turenlong.com 限时下载地址:htt ...

  10. 窥探Swift之数组安全索引与数组切片

    今天是元宵节,祝大家元宵节快乐!在Swift中的数组和字典中下标是非常常见的,数组可以通过索引下标进行元素的查询,字典可以通过键下标来获取相应的值.在使用数组时,一个常见的致命错误就是数组越界.如果在 ...

随机推荐

  1. Think in Java 第三章操作符

    Think in Java 第三章操作符 赋值 对象赋值 ​ 我们真正操作的是对对象的引用.所以倘若"将一个对象赋值给另一个对象",实际上是将"引用"从一个地方 ...

  2. DFS——求图的连通性问题

    DFS作为一个竞赛必学的一个知识点,怎么说我都得写一下 遍历就相当于爆搜,只不过是搜的方式比较规整罢了. 深度优先遍历:为了避免重复访问某个顶点,可以设一个标志数组vis[i],未访问时值为0,访问一 ...

  3. Traveling Salesman among Aerial Cities 旅行商(TSP)问题

    题目链接:点我 问题: 给你n个点的坐标(x,y,z).从点(a,b,c) 到另一个点 (p,q,r) 的距离是:|p−a|+|q−b|+max(0,r−c) 问你从一个点为起点,找一条能经过其他所有 ...

  4. 【noi 2.6_9281】技能树(DP)

    题意:要求二叉树中每个节点的子节点数为0或2,求有N个节点高度为M的不同的二叉树有多少个(输出 mod 9901 后的结果). 解法:f[i][j]表示高度为i的有j个节点的二叉树个数.同上题一样,把 ...

  5. HDU -1506 Largest Rectangle in a Histogram&&51nod 1158 全是1的最大子矩阵 (单调栈)

    单调栈和队列讲解:传送门 HDU -1506题意: 就是给你一些矩形的高度,让你统计由这些矩形构成的那个矩形面积最大 如上图所示,如果题目给出的全部是递增的,那么就可以用贪心来解决 从左向右依次让每一 ...

  6. Codeforces Round #672 (Div. 2 B. Rock and Lever (位运算)

    题意:给你一组数,求有多少对\((i,j)\),使得\(a_{i}\)&\(a_{j}\ge a_{i}\ xor\ a_{j}\). 题解:对于任意两个数的二进制来说,他们的最高位要么相同要 ...

  7. Codeforces Round #643 (Div. 2) E. Restorer Distance (贪心,三分)

    题意:给你\(n\)个数,每次可以使某个数++,--,或使某个数--另一个++,分别消耗\(a,r,m\).求使所有数相同最少的消耗. 题解:因为答案不是单调的,所以不能二分,但不难发现,答案只有一个 ...

  8. 同时拿到BATJMD的Offer是怎样的一种体验?

    写在前面 又到了收割Offer的季节,你准备好了吗?曾经的我,横扫各个大厂的Offer.还是那句话:进大厂临时抱佛脚是肯定不行的,一定要注重平时的总结和积累,多思考,多积累,多总结,多复盘,将工作经历 ...

  9. Python3.7.9+Locust1.4.3版本性能测试工具案例分享

    一.Locust工具介绍 1.概述 Locust是一款易于使用的分布式负载测试工具,完全基于事件,使用python开发,即一个locust节点也可以在一个进程中支持数千并发用户,不使用回调,通过gev ...

  10. 洛谷P1462-通往奥格瑞玛的道路-二分+最短路

    洛谷P1462-通往奥格瑞玛的道路 题目描述 在艾泽拉斯,有\(n\)个城市.编号为\(1,2,3,...,n\). 城市之间有\(m\)条双向的公路,连接着两个城市,从某个城市到另一个城市,会遭到联 ...