切片

切片是由数组建立的一种方便、灵活且功能强大的包装(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. OLAP、OLTP的介绍和比较(转载)

    OLTP与OLAP的介绍 数据处理大致可以分成两大类:联机事务处理OLTP(on-line transaction processing).联机分析处理OLAP(On-Line Analytical ...

  2. poj 1511-- Invitation Cards (dijkstra+优先队列)

    刚开始想复杂了,一直做不出来,,,其实就是两遍dijkstra+优先队列(其实就是板子题,只要能有个好的板子,剩下的都不是事),做出来感觉好简单...... 题意:有n个车站和n个志愿者,早上每个志愿 ...

  3. poj3252 Round Numbers (数位dp)

    Description The cows, as you know, have no fingers or thumbs and thus are unable to play Scissors, P ...

  4. tomacat服务器上web资源访问流程、web应用打成war包发布、Context的reloadable属性、tomacat体系架构

    一.web资源访问流程 二.web应用打成war包发布到服务器 好处:打成war包发布到服务器,那么服务器会自动把它拆解成文件夹 jar命令是java自带的一个命令,如果之前配置过Java编译环境就可 ...

  5. K8S(16)集成实战-使用spinnaker进行自动化部署

    K8s集成实战-使用spinnaker进行自动化部署 1 spinnaker概述和选型 1.1 概述 1.1.1 主要功能 Spinnaker是一个开源的多云持续交付平台,提供快速.可靠.稳定的软件变 ...

  6. HEXO添加置顶功能

    使用库:参考 http://wangwlj.com/2018/01/09/blog_pin_post/ 目前已经有修改后支持置顶的仓库,可以直接用以下命令安装.(cmd 到博客根目录,nmp运行) $ ...

  7. 读js DOM编程艺术总结

    第一章主要介绍一些历史性问题,javascript是Netcape和sun公司合作开发的. 第二章JavaScript语法: 1,数据类型:(弱类型)字符串,数值,布尔值(只有true和false,不 ...

  8. Python+OpenCV+图片旋转并用原底色填充新四角

    import cv2 from math import fabs, sin, cos, radians import numpy as np from scipy.stats import mode ...

  9. free online markdown editor

    free online markdown editor markdown https://blog.csdn.net/xgqfrms/article/details/50129317 In-brows ...

  10. Vue & mobile UI components

    Vue & mobile UI components https://github.com/vuejs/awesome-vue https://awesome-vue.js.org/ http ...