第三章、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 ...
随机推荐
- http协议之状态码
=================状态码,状态文字======================== 状态码:用来反应服务器的响应状态 状态文字:是用来说明状态码的. 状态码:可以分为这5个大的部分 - ...
- redis在asp.net 中的应用
1.redis介绍 Nosql数据库作为关系型数据库的补充,在互联网公司已经得到广泛的运用.redis便是其中的代表之一,redis是一种(key,value)基于内存的数据库,并支持多种数据结构,如 ...
- Redis 学习笔记(篇四):整数集合和压缩列表
整数集合 Redis 中当一个集合(set)中只包含整数,并且元素不多时,底层使用整数集合实现,否则使用字典实现. 那么: 为什么会出现整数集合呢?都使用字典存储不行吗? 整数集合在 Redis 中的 ...
- Delphi7中Unicode,ANSI,UTF编码问题
注解: ANSI 'American Standard Code for Information Interchange' 美国信息互换标准代码 ANSI的'Ascii'编码 Unicode ...
- CSU 1804: 有向无环图(拓扑排序)
http://acm.csu.edu.cn/csuoj/problemset/problem?pid=1804 题意:…… 思路:对于某条路径,在遍历到某个点的时候,之前遍历过的点都可以到达它,因此在 ...
- 数据结构与算法分析(C++)读书笔记
第一章 综述 数学知识复习: 指数.对数.级数.模运算.证明方法(证明数据结构分析几轮最常用方法:归纳法.反证法) 递归简论 C++知识:类.细节.模板.矩阵.
- Centos7:yum安装MySQL5.7后如何设置root密码
Centos下安装软件的方式很简单,只需要通过yum install xxx命令即可.第一步当然检查是否有mysql的yum源,命令:yum list|grep mysql-community[主要还 ...
- Python重试模块retrying
Python重试模块retrying 工作中经常碰到的问题就是,某个方法出现了异常,重试几次.循环重复一个方法是很常见的.比如爬虫中的获取代理,对获取失败的情况进行重试. 刚开始搜的几个博客讲的有点问 ...
- 在CentOS6.5部署Redis为开机自启
2 - redis的生产启动方案 要把redis作为一个系统的daemon进程 去运行的,每次系统启动,redis进程一起启动,配置方案如下: 1. 在redis utils 目录下,有个redis_ ...
- openstack实验环境搭建
Openstack实验文档 一.base节点 1.1配置网络 vim /etc/sysconfig/network-scripts/ifcfg-eth0 1.2关闭防火墙和selinux system ...