> ### 例子一
* 当切片长度小于1024时, 扩容为原来的2倍, 大于或等于1024时, 扩容1.25倍
* slice\[start:end:cap\]
~~~
package main
import "fmt"
// make([]T, length长度, capacity容量)
// 一般使用make()创建 : 用len获取切片长度, cap获取切片容量
// 一个切片在未初始化之前默认为 nil,长度为 0
// 切片是基于数组类型做的一层封装,自动扩容
// 与数组相比切片的长度是不固定的,可以追加元素,在追加时可能使切片的容量增大
func main() {
var number1 []string
number2 := []string{"A", "B", "C"}
number3 := make([]int, 2, 2)
number4 := append(number3, []int{3, 4, 5}...) //number4 := append(number3,number3...)//用省略号自动展开切片,以使用每个元素
//长度和容量 切片再切片
//cap 省略时 默认等于 len
//number5... 展开number5切片成一个个元素
// var a[5]int = [5]int{5, 4, 3, 2, 1} //sort.Ints(a[:])
fmt.Println("Number1:", number1)
fmt.Println("Number2:", number2)
fmt.Printf("Number3: %d, len:%d, cap:%d\n", number3, len(number3), cap(number3))
fmt.Printf("Number4: %d, len:%d, cap:%d\n", number4, len(number4), cap(number4))
number5 := []string{"A", "B", "C"}
number6 := []string{"D", "E"}
number7 := copy(number6, number5) //等位替换原切片(返回替换成功的个数)
fmt.Printf("Number6: copy success number %d --- %s\n", number7, number6)
}
~~~
> ### 例子二
~~~
package main
import "fmt"
func main() {
//[start:end] [start:] [:end] [:] -- 第三个参数: 递增
number8 := []int{9, 12, 35, 41, 95, 60, 17, 66, 9, 10}
fmt.Println("Number8-1:", number8[3:6])
//切片是引用类型(对数组的引用)
fmt.Printf("Number8-2: %d, Addr:%p, Len:%d, Cap:%d \r\n", number8, number8, len(number8), cap(number8))
number9 := number8
number9[3] = 77
fmt.Printf("Number8-3: %d, Addr:%p, Len:%d, Cap:%d", number8, number8, len(number8), cap(number8))
fmt.Println("")
number8 = append(number8, 11)
number9[3] = 88
fmt.Printf("Number8-4: %d, Addr:%p Len:%d, Cap:%d", number8, number8, len(number8), cap(number8))
}
~~~
> ### 例子三
~~~
package main
import "fmt"
func main() {
number1 := make([]int, 1, 2)
fmt.Printf("%p\n", number1) //图1
fmt.Printf("%p\n", &number1[0]) //图2
fmt.Printf("%p\n", &number1) //图3 切片变量的地址(ptr len cap)
}
~~~
![](/D:/%E6%AD%A3%E5%BC%8F%E6%A1%8C%E9%9D%A2/Golang%E5%B7%A5%E4%BD%9C%E7%AC%94%E8%AE%B0/book/Golang%E5%B7%A5%E4%BD%9C%E7%AC%94%E8%AE%B0/images/QQ%E6%88%AA%E5%9B%BE20180919094228.jpg)
> ### 例子四
~~~
package main
import "fmt"
func main() {
//->■■■■■□□□□□
number1 := make([]int, 5, 10)
//fmt.Println(number1[5]) //超出下标索引
//■■ ->■■■■■□□□
number2 := number1[2:7]
fmt.Println(number2, cap(number2))
}
~~~
> ### 例子五
~~~
package main
import "fmt"
func main() {
//->■■■■■□□□□□
number1 := make([]int, 5, 10)
//■■ ->■■■■■□□□
number2 := number1[2:7]
number1[3] = 3
fmt.Println(number1)
fmt.Println(number2)
number2[3] = 4
fmt.Println(number1)
fmt.Println(number2)
}
~~~
> ### 例子6(去掉TODO2再看下打印结果)--(对一个变量追加元素,扔到新变量上,那么旧的变量就没用了)
~~~
package main
import "fmt"
func main() {
x := []int{1}
fmt.Println("-----TODO1-----")
fmt.Printf("%v, %d, %d\n", x, len(x), cap(x))
fmt.Println("-----TODO2-----")
x = append(x, 3)
fmt.Printf("%v, %d, %d\n", x, len(x), cap(x))
fmt.Println("-----TODO3-----")
x = append(x, 5)
fmt.Printf("%v, %d, %d\n", x, len(x), cap(x))
fmt.Println("-----TODO4-----")
y := append(x, 7)
fmt.Printf("%v, %d, %d\n", x, len(x), cap(x))
fmt.Printf("%v, %d, %d\n", y, len(y), cap(y))
fmt.Println("-----TODO5-----")
z := append(x, 9)
fmt.Printf("%v, %d, %d\n", x, len(x), cap(x))
fmt.Printf("%v, %d, %d\n", z, len(z), cap(z))
fmt.Println("-----TODO6-----")
fmt.Println(x, y, z)
}
~~~
> ### copy
~~~
package main
import "fmt"
func main() {
//`copy` 函数`copy`从源`slice`的`src`中复制元素到目标`dst`,并且返回复制的元素的个数
number1 := []int{1, 2, 3, 4, 5}
number2 := []int{6, 7, 8}
number3 := copy(number1, number2)
fmt.Println(number1, number2, number3)
number4 := []int{1, 2, 3, 4, 5}
number5 := []int{6, 7, 8}
number6 := copy(number5, number4)
fmt.Println(number4, number5, number6)
}
~~~
> ### append
~~~
package main
import "fmt"
func main() {
//`append` 向`slice`里面追加一个或者多个元素,然后返回一个和`slice`一样类型的`slice`
number1 := []int{1, 2, 3}
fmt.Println(number1, len(number1), cap(number1))
number1 = append(number1, 4, 5)
fmt.Println(number1, len(number1), cap(number1)) //按初始容量成倍扩大
number3 := append(number1, number1...) //用省略号自动展开切片,以使用每个元素
fmt.Println(number3)
}
~~~
- 第一序 入门教程(一)
- 1.1环境配置
- 1.1 环境配置(补充:Linux下安装)
- 1.1 环境配置(补充:线上部署)
- 1.2 开发工具GoLand
- 1.3 准备工作
- 1.4 第一个应用程序 Hello World
- 1.4 补充 go get github 超时
- 第二序 入门教程(二)
- 2.1 语法结构
- 2.2 常量, 变量
- 2.2.1 命名规则
- 2.2.2 变量
- 2.2.2 变量(补充:类型推断的好处)
- 2.2.2 变量(补充:泛型)
- 2.2.3 常量
- 2.2.4 iota
- 2.2.5 Unicode字符编码
- 2.2.6 GBK 转 UTF8
- 2.3 条件语句
- 2.3.1 判断语句 if
- 2.3.2 选择语句 switch
- 2.3.3 循环语句 for
- 2.3.4 遍历 range
- 2.3.5 跳转语句 goto, break, continue
- 2.3.6 for 和 for range区别
- 2.4 数组, 切片, 集合, 通道
- 2.4.1 make, len, cap, new, nil
- 2.4.1 make, len, cap, new, nil (补充:nil)
- 2.4.2 数组 array
- 2.4.3.1 切片 slice - 1
- 2.4.3.2 切片 slice - 2
- 2.4.3.3 slice list ring
- 2.4.4 集合 map
- 2.4.5 goroutine
- 2.4.6 channel
- 2.5 函数, 结构, 方法, 接口
- 2.5.1 函数 function
- 2.5.2 结构 struct
- 2.5.3 方法 method
- 2.5.4 接口 interface
- 2.5.5 Go是面向对象的语言吗?
- 2.5.6 json序列化和反序列化
- 2.5.7 T和指针T
- 2.6 defer, panic, recover
- 2.6.1 defer
- 2.6.2 painc, recover
- 2.7 指针
- 2.7 指针(补充: 可寻址和不可寻址)
- 2.8 反射
- 第三序 相关阅读
- 3.1 相关阅读1
- 3.2 相关阅读2
- 3.3 相关阅读3
- 第四序 性能分析和调试工具
- 4.1 pprof工具介绍
- 4.2 CPU信息采集
- 4.3 Heap信息采集
- 4.4 Http信息采集
- 4.5 单元测试(功能测试)
- 4.6 基准测试(压力测试/性能测试)
- 4.7 示例测试(example)
- 4.8 gdb调试
- 第五序 网络编程
- 5.1 http请求和响应
- 5.2 socket
- 5.2.1 概念
- 5.2.2 服务端
- 5.2.3 客户端
- 5.3 WebSocket
- 5.3.1 第一版
- 5.3.1.1 服务端
- 5.3.1.2 客户端
- 5.3.1.3 相关阅读
- 5.3.2 服务端
- 5.3.3 客户端
- 5.3.4 nginx配置
- 5.3.5 修改版
- 5.3.5.1 草稿 - 1
- 5.3.5.2 草稿 - 2
- 5.3.5.3 草稿 - 3
- 5.3.5.4 服务端
- 5.3.5.5 客户端
- 5.4 打印客户端头部信息
- 第六序 算法
- 6.1 查找
- 6.1.1 二分查找
- 6.2 排序
- 6.2.1 交换排序 - 冒泡排序
- 6.2.2 插入排序 - 直接插入排序
- 6.2.3 插入排序 - 希尔排序
- 6.2.4 交换排序 - 快速排序
- 6.3 算法求解应用
- 第七序 微服务
- 7.1 相关阅读
- 7.2 gRPC
- 7.2.1 准备工作
- 7.2.2 编译.proto文件
- 7.2.3 gRPC服务端
- 7.2.4 gRPC客户端
- 7.3 micro/micro
- 7.3.1 服务发现
- 7.3.2 安装consul
- 7.3.3 准备工作
- 7.3.4 服务端
- 7.3.5 客户端
- 7.3.6 默认的服务发现
- 7.3.7 文档阅读
- 7.4 protobuf序列化
- 第八序 Web
- 8.1 视图模板
- 8.1.1 main.go
- 8.1.2 login.html
- 8.2 原生留言板
- 8.2.1 原生sql
- 8.2.1.1 main.go
- 8.2.1.2 view
- 8.2.1.2.1 index.html
- 8.2.1.2.2 create.html
- 8.2.2 sqlx
- 8.3 Gin框架
- 第九序 数据库
- 9.0 资料收集
- 9.1 Redis数据库 (gomodule/redigo)
- 9.1.1 介绍
- 9.1.2 消息队列
- 9.2 Redis数据库(go-redis/redis)
- 第十序 日记
- 10.1 SimplePanic
- 10.2 第一版日记库
- 10.2.1 winnielog
- 10.2.2 使用
- 第十一序 中间键
- 11.0 资料收集
- 11.1 NSQ
- 11.2 zookeeper
- 11.3 kafka
- 第十二序 加密
- 12.1 Token
- 12.2 SHA1
- 2.3 RSA + AES
- 第十三序 分布式锁
- 第十四序 标准库练习
- container/list
- 链表
- container/ring
- 环形链表
- context
- flag (获取命令行参数)
- io
- strconv
- sync
- 为什么需要锁?
- 互斥锁
- 读写锁
- 条件变量
- 计数器
- 并发安全字典
- 自制并发安全字典
- 官方并发安全字典
- 连接池
- sync/atomic
- 原子操作
- 第十五序 其它内容
- 文件读写
- 工作池
- 第十六序 相关阅读