第三章、Go-内建容器
3.1.数组
(1)数组的定义
package main import (
"fmt"
) func main() {
//用var定义数组可以不用赋初值
var arr1 [5]int //[0 0 0 0 0]
//用冒号必须指定初值
arr2 := [3]int{1,3,5} //[1 3 5]
//用“...”表示任意个数
arr3 := [...]int{2,4,6,8,10} //[2 4 6 8 10]
fmt.Println(arr1,arr2,arr3)
}
(2)数组的遍历
用range关键字
package main import (
"fmt"
) func main() {
arr3 := [...]int{2,4,6,8,10} //[2 4 6 8 10]
fmt.Println(arr3) //数组的遍历
for i := range arr3{
fmt.Println(arr3[i])
}
} //结果
2
4
6
8
10
获取下标和值
package main import (
"fmt"
) func main() {
arr3 := [...]int{2,4,6,8,10} //[2 4 6 8 10]
fmt.Println(arr3) //数组的遍历
for i ,v:= range arr3{
fmt.Println(i,v)
}
} //结果
0 2
1 4
2 6
3 8
4 10
(3)数组是值类型
- [10]int和[20]int是不同类型
- 调用func f(arr [10]int) 会拷贝数组
- 在go语言中一般不使用数组,而使用切片
package main import (
"fmt"
) func printArray(arr [5]int){
for i ,v:= range arr{
fmt.Println(i,v)
}
} func main() {
//arr2 := [3]int{1,3,5}
arr3 := [...]int{2,4,6,8,10}
printArray(arr3)
} //结果
0 2
1 4
2 6
3 8
4 10
如果传arr2则报错
package main import (
"fmt"
) func printArray(arr [5]int){
for i ,v:= range arr{
fmt.Println(i,v)
}
} func main() {
arr2 := [3]int{1,3,5}
//arr3 := [...]int{2,4,6,8,10}
printArray(arr2) //cannot use arr2 (type [3]int) as type [5]int in argument to printArray
}
3.2.切片
(1)切片
package main
import "fmt"
func main() {
arr := [...]int{0,1,2,3,4,5,6,7}
fmt.Println(arr[2:6]) //[2 3 4 5]
fmt.Println(arr[:6]) //[0 1 2 3 4 5]
fmt.Println(arr[2:]) //[2 3 4 5 6 7]
fmt.Println(arr[:]) //[0 1 2 3 4 5 6 7]
}
(2)slice的扩展
slice可以向后扩展,不可以向前扩展
package main
import "fmt"
func main() {
arr := [...]int{0,1,2,3,4,5,6,7}
s1 := arr[2:6]
s2 := s1[3:5]
fmt.Println(s1) //[2 3 4 5]
fmt.Println(s2) //[5 6]
}
s2是如何取到[5,6]的

(3)slice的实现
slice底层隐藏了三个值

s[i]不可以超越len(s),向后扩展不可以超越底层数组cap(s)
package main
import "fmt"
func main() {
arr := [...]int{0,1,2,3,4,5,6,7}
s1 := arr[2:6]
s2 := s1[3:5]
fmt.Println("arr = ",arr) //arr = [0 1 2 3 4 5 6 7]
fmt.Printf("s1=%v,len(s1)=%d,cap(s1)=%d\n",s1,len(s1),cap(s1)) //s1=[2 3 4 5],len(s1)=4,cap(s1)=6
fmt.Printf("s2=%v,len(s2)=%d,cap(s2)=%d\n",s2,len(s2),cap(s2)) //s2=[5 6],len(s2)=2,cap(s2)=3
fmt.Println(s1[3:6]) //[5 6 7]
}
3.3.切片的操作
(1)向slice添加元素
- 添加元素时,如果超出了cap,系统会重新分配更大的底层数组
- 由于值传递的关系,必须接收append的返回值。s = append(s,val)
package main
import "fmt"
func main() {
arr := [...]int{0,1,2,3,4,5,6,7}
s1 := arr[2:6] //[2 3 4 5]
s2 := s1[3:5] //[5 6]
s3 := append(s2,10)
s4 := append(s3,11)
s5 := append(s4,12)
fmt.Println(s3,s4,s5) //[5 6 10] [5 6 10 11] [5 6 10 11 12]
//因为s2的cap是[5,6,7],s3 append把7替换成10,s4后超出了cap
fmt.Println(arr) //[0 1 2 3 4 5 6 10]
}
(2)slice的创建
package main
import "fmt"
func main() {
//第一种
//Zero value for slice is nil
var s1 []int
fmt.Println(s1) //[]
for i := 0; i < 5 ; i++{
s1 = append(s1,i)
}
fmt.Println(s1) //[0 1 2 3 4]
//第二种
s2 := []int{2,4,6,8}
fmt.Printf("len(s2)=%d,cap(s2)=%d\n",len(s2),cap(s2)) //len(s2)=4,cap(s2)=4
//第三种
s3 := make([]int,16)
fmt.Printf("len(s3)=%d,cap(s3)=%d\n",len(s3),cap(s3)) //len(s3)=16,cap(s3)=16
//第四种
s4 := make([]int,16,32)
fmt.Printf("len(s4)=%d,cap(s4)=%d\n",len(s4),cap(s4)) //len(s4)=16,cap(s4)=32
}
(3)slice的删除
package main
import "fmt"
func main() {
s1 := []int{0,1,2,3,4,5,6}
fmt.Println(s1) //[0 1 2 3 4 5 6]
//删除index为3的值
s1 = append(s1[:3],s1[4:]...)
fmt.Println(s1) //[0 1 2 4 5 6]
}
3.4.Map
(1)map的三种建立方式
package main
import "fmt"
func main() {
//第一种
m1 := map[string]string{
"name": "derek",
"course": "go",
"city": "guangdong",
}
fmt.Println(m1) //map[city:guangdong course:go name:derek]
//第二种
m2 := make(map[string]int)
fmt.Println(m2) //map[]
//第三种
var m3 map[string]string
fmt.Println(m3) //map[]
}
(2)map的遍历
package main
import "fmt"
func main() {
m1 := map[string]string{
"name": "derek",
"course": "go",
"city": "guangdong",
}
fmt.Println(m1) //map[city:guangdong course:go name:derek]
for k,v := range m1{
fmt.Println(k,v)
}
}
//结果
name derek
course go
city guangdong
(3)值的获取
key存在获取,不存在则得到空值
package main
import "fmt"
func main() {
m1 := map[string]string{
"name": "derek",
"course": "go",
"city": "guangdong",
}
fmt.Println(m1) //map[city:guangdong course:go name:derek]
//获取map中key的value
courseName := m1["course"]
fmt.Println(courseName) //go
//如果key不存在,不会报错,而是得到一个空值
age := m1["age"]
fmt.Println(age) //空值
}
(4)用if判断取值
package main
import "fmt"
func main() {
m1 := map[string]string{
"name": "derek",
"course": "go",
"city": "guangdong",
}
fmt.Println(m1) //map[city:guangdong course:go name:derek]
//key存在,ok = true
courseName,ok := m1["course"]
fmt.Println(courseName, ok) //go true
//key不存在,ok = false
age, ok := m1["age"] // ok = false
fmt.Println(age,ok)
//取值的时候加一个判断,ok=true取值,否则打印值不存在
if age, ok := m1["age"]; ok{
fmt.Println(age)
}else {
fmt.Println("key does not exist")
}
}
(5)删除key
package main
import "fmt"
func main() {
m1 := map[string]string{
"name": "derek",
"course": "go",
"city": "guangdong",
}
fmt.Println(m1) //map[city:guangdong course:go name:derek]
//删除key
delete(m1,"city")
fmt.Println(m1) //map[course:go name:derek]
}
第三章、Go-内建容器的更多相关文章
- OpenGL ES着色器语言之语句和结构体(官方文档第六章)内建变量(官方文档第七、八章)
OpenGL ES着色器语言之语句和结构体(官方文档第六章) OpenGL ES着色器语言的程序块基本构成如下: 语句和声明 函数定义 选择(if-else) 迭代(for, while, do-wh ...
- go内建容器-Map
1.基础定义 golang中的map如同它的函数一样"纯粹",map就是用来存储键值对的容器,别管什么哈希不哈希的(底层已实现),用就行 //创建一个map m := map[st ...
- go内建容器-切片
1.基础定义 看到'切片'二字,满脸懵逼.切的啥?用的什么刀法切?得到的切片有什么特点?可以对切片进行什么操作? 先看怎么得到切片,也就是前两个问题.切片的底层是数组,所以切片切的是数组:切的时候采用 ...
- go内建容器-数组
1.基础定义 声明时数组长度在数组成员类型前 语法:var variableName [length]int //基本定义 var array1 [3]int //定义并赋值 var array2 = ...
- 第三章JavaScript 内置对象
1 Number 1.1 属性 MAX_VALUE JS可以表示的最大的数字 MIN_VALUE JS可以表示的最小的数字 1.2 方法 toFixed(length) 指定保留长度的小数 toExp ...
- go内建容器-字符和字符串操作
1.基础定义 在基础语法篇提到过golang的rune相当于其他编程语言的char,其本质是一个int32(四字节),用[]rune来转换一个字符串时,得到的是个解码后的结果,存储在新开辟的[]run ...
- golang内建容器
- 跟着老猫来搞GO-内建容器Map
前期回顾 在上面的文章中,老猫和大家分享了GO语言中比较重要的两种数据结构,一种是数组,另外一种是基于数组的slice.本篇文章想要继续和大家分享剩下的容器以及字符字符串的处理. MAP map的定义 ...
- 18第一章 ASP.Net内建对象
第一章 ASP.Net内建对象 第一章 ASP.Net内建对象 ASP.Net为保持用户的数据和信息,内建了许多对象,包括Application.Response.Requ ...
随机推荐
- OVS实现VXLAN隔离
一.实验环境 1.准备3个CentOS7 mini版本的虚拟机,每个主机3个网卡.如图: 图中OVS-1.OVS-2.OVS-3分别为三台CentOS7 mini版虚拟机,分别配备3个虚拟网卡.如图中 ...
- Hive 学习之路(五)—— Hive 分区表和分桶表
一.分区表 1.1 概念 Hive中的表对应为HDFS上的指定目录,在查询数据时候,默认会对全表进行扫描,这样时间和性能的消耗都非常大. 分区为HDFS上表目录的子目录,数据按照分区存储在子目录中.如 ...
- python3的类
python3的类: python是一门面向对象的编程语言,学习python下的类,,能帮助自己形成一个基本的面向对象的概念.关于类和实例的理解,一个易懂的栗子就是动物类,我们把动物看做一个类,而狗啊 ...
- 渐进式web应用开发---service worker (二)
阅读目录 1. 创建第一个service worker 及环境搭建 2. 使用service worker 对请求拦截 3. 从web获取内容 4. 捕获离线请求 5. 创建html响应 6. 理解 ...
- python logging模块使用总结
目录 logging模块 日志级别 logging.basicConfig()函数中的具体参数含义 format参数用到的格式化信息 使用logging打印日志到标准输出 使用logging.base ...
- MySQL索引的数据结构-B+树介绍
目录 一.树 二.B+树 2.1 B+树性质 三.聚集索引和辅助索引 3.1 聚集索引 3.2 辅助索引 3.3 聚集索引和非聚集索引的区别 四.再看B+树 4.1 B+树的插入操作 4.2 B+树的 ...
- 用python的matplotlib和numpy库绘制股票K线均线和成交量的整合效果(含量化验证交易策略代码)
在用python的matplotlib和numpy库绘制股票K线均线的整合效果(含从网络接口爬取数据和验证交易策略代码)一文里,我讲述了通过爬虫接口得到股票数据并绘制出K线均线图形的方式,在本文里,将 ...
- 并发编程-concurrent指南-阻塞队列-链表阻塞队列LinkedBlockingQueue
LinkedBlockingQueue是一个基于链表的阻塞队列. 由于LinkedBlockingQueue实现是线程安全的,实现了先进先出等特性,是作为生产者消费者的首选. LinkedBlocki ...
- Codeforces Gym100502H:Clock Pictures(KMP算法)
http://codeforces.com/gym/100502/attachments 题意:有两个时钟上面有n个指针,给出的数字代表指针的角度.问能否在某一时刻使得两个时钟的指针重合. 思路:容易 ...
- c++汉诺塔问题
c++解决汉诺塔问题 题目描述 约19世纪末,在欧州的商店中出售一种智力玩具,在一块铜板上有三根杆,最左边的杆上自上而下.由小到大顺序串着由64个圆盘构成的塔.目的是将最左边杆上的盘全部移到中间的杆上 ...