内置函数
1.close: 主要是用来关闭channel
2.len:用来求长度,比如string、array、slice、map、channel
3.new与make都是用来分配内存
new用来分配值类型,如int、string,返回的是指针
make用来分配引用类型,如chan、map、slice
new创建的指针指向变量,make进行变量的初始化 4.append用来追加元素到数组、slice中
5.panie和recover,用来做错误处理 闭包
1。一个函数和与其相关的饮用环境组合而成的实体
package main import "fmt"
func Addr() func(int) int {
var x int
return func(d int) int {
x +=d
return x
}
}
func main() {
f := Addr()
fmt.Println(f(1))
fmt.Println(f(100))
fmt.Println(f(1000))
} 数组 1.数组:
是同一种数据类型的固定长度的序列
2.数组定义
var a [len]int
3.长度是数据类型的一部分,因此,var a[5] int和var a[10] int是不同类型
4.数据可以通过下标进行访问,下标是从0开始,最后一个元素的下标为len-1
5.访问越界,如果下标在数组合法范围之外,则触发访问越界,会panic
6.数组的初始化
a.var age() [5]int = [5] int{1,2,3,4,5}
b.var age() = [5]int{1,2,3,4,5}
c.var age = [...]int {1,2,3,4,5}
d.var str = [5]string{3:"hello world",4:"tom"}
7.多维数组
a.var age [5][3]int
b.var f [2][3]int = [...][3]int{{1,2,3},{4,5,6}} 切片 1.切片,切片是数组的一个引用,因此切片是引用类型
2.切片的长度可以改变,因此,切片是一个可变数组
3.切片遍历方式和数组一样,可以用len()求长度
4.cap可以求出slice最大的容量,0<=len(slice) <=cap(array),其中arrayshi slice引用的数组
5.切片的定义
var 变量名 []类型,比如 var str []string var arr []int
6.切片的初始化:
var slice []int = arr[start:end]
var slice []int = arr[0:end] 简写为 var slice []int = arr[:]
var slice []int = arr[start:len(arr)]简写为var slice[]int = arr[start:]
var slice []int = arr[0,len(arr)]简写为 var slice[]int = arr[:]
7.通过make创建切片
var slice []type = make([]type,len)
slice := make([]type,len)
slice := make([]type,len,cap)
8.用append内置函数操作切片
slice = append(slice,10)
var a = []int {1,2,3}
var b = []int {4,5,6}
a = append(a,b...)
9.切片拷贝
s1 := []int{1,2,3,4,5}
s2 := make([]int,10)
copy(s2,s1) // copy不会扩容,append会。
s3 := []int{1,2,3}
s3 = append(s3,s2...)
s3 = append(s3,4,5,6)
10.字符串改字符
s := "hello world"
s1 := []rune(s) //[]byte(s)
s1[0] = '0'
str := string(s1) 排序
1.sort.Ints()对证书进行排序
2.sort.String对字符和窜进行排序
3.sort.Float64s对浮点型进行排序
4.sort.SearchInte(a []int,b int)从数组a中查找b。前提是a有序
5.sort.SearchFloats(a []float64,b float64)从数组a中查找b。前提是a有序
7.sort.SearchStrings(a []string,b string)从数组a中查找b。前提是a有序 map
1.key-value的数据结构,又叫字典或关联数组
a.声明
var map1 map[keytype]valuetype
var a map[string]string
var a map[string]int
var a map[int]string
var a map[string]map[string]string
//声明不会分配内存,初始化需要make 锁 1.互斥锁
sync.Mutex
var lock sync.Mutex
func test() {
var a map[int]int
a = make(map[int]int)
a[7] = 10
a[5] = 10
a[3] = 10
a[1] = 10
for i :=0;i<3;i++{
go func(b map[int]int){
lock.Lock()
b[8] = rand.Intn(100)
lock.Unlock()
}(a)
lock.Lock()
fmt.Println(a)
lock.Unlock()
time.sleep(time.Second)
}
}
2.读写锁
var mu sync.RWMutex
go build -race 目录 检测代码是否有冲突

  

go:内置函数 | 闭包 | 数组 | 切片 | 排序 | map | 锁的更多相关文章

  1. Python函数05/内置函数/闭包

    Python函数05/内置函数/闭包 目录 Python函数05/内置函数/闭包 内容大纲 1.内置函数(二) 2.匿名函数及内置函数(重要) 3.闭包 4.今日总结 5.今日练习 内容大纲 1.内置 ...

  2. awk(流程控制、内置变量、内置函数、数组)

    摘自:http://bbs.51cto.com/thread-883948-1-1.html awk(流程控制.内置变量.内置函数.数组) ... 参考其他的资料,给大家看看.一.awk流程控制语句 ...

  3. 12.Python略有小成(生成器,推导式,内置函数,闭包)

    Python(生成器,推导式,内置函数,闭包) 一.生成器初始 生成器的本质就是迭代器,python社区中认为生成器与迭代器是一种 生成器与迭代器的唯一区别,生成器是我们自己用python代码构建成的 ...

  4. Python 内置函数 -- zip(), sorted(), filter()和map()

    内置函数1. zip() 打包(木桶效应)描述: zip() 函数用于将可迭代的对象作为参数, 将对象中对应的元素打包成一个个元组, 然后返回由这些元组组成的列表语法: zip([iterable, ...

  5. python内置函数lambda、filter、map、reduce

    lambda匿名函数 1.lambda只是一个表达式,函数体比def简单多. 2.lambda的主体是一个表达式,而不是一个代码块.仅仅能在lambda表达式中封装有限的逻辑进去 3.lambda函数 ...

  6. 内置函数系列之 sorted排序

    sorted排序函数语法: sorted(可迭代对象,key=函数(默认为None),reverse=False) 将可 迭代对象的每一个元素传进key后面的函数中,根据函数运算的结果(返回值)进行排 ...

  7. Python 内置函数、作用域、闭包、递归

    一.内置函数如何使用 help()一下: 如想看min()咋用?在shell中:help(min) 二.部分内置函数 (一).排序:sorted() li = [(1, 2, 3, 4), (7, 8 ...

  8. 4 python内置函数

    1.内置函数的整体介绍 内置参数官方详解 https://docs.python.org/3/library/functions.html?highlight=built#ascii 2.各内置函数介 ...

  9. Python学习(五)函数 —— 内置函数 lambda filter map reduce

    Python 内置函数 lambda.filter.map.reduce Python 内置了一些比较特殊且实用的函数,使用这些能使你的代码简洁而易读. 下面对 Python 的 lambda.fil ...

随机推荐

  1. Lego:美团点评接口自动化测试实践

    概述 接口自动化概述   众所周知,接口自动化测试有着如下特点: 低投入,高产出. 比较容易实现自动化. 和UI自动化测试相比更加稳定. 如何做好一个接口自动化测试项目呢? 我认为,一个“好的”自动化 ...

  2. 码海拾遗:Linux多线程mutex锁

    多线程计数,每个线程累加10个数. 实现: #include <stdio.h> #include <stdlib.h> #include <string.h> # ...

  3. 虚拟桌面软件CitrixReceiver相关问题

    由于安过一次,卸载再次安装程序报错: 原因:卸载不干净,导致再次安装部分插件未成功安装 解决: 1.在控制面板卸载Citrix receiver 2.删除C:\Program Files (x86)\ ...

  4. ES6学习笔记(三):教你用js面向对象思维来实现 tab栏增删改查功能

    前两篇文章主要介绍了类和对象.类的继承,如果想了解更多理论请查阅<ES6学习笔记(一):轻松搞懂面向对象编程.类和对象>.<ES6学习笔记(二):教你玩转类的继承和类的对象>, ...

  5. ElasticSearch实战系列五: ElasticSearch的聚合查询基础使用教程之度量(Metric)聚合

    Title:ElasticSearch实战系列四: ElasticSearch的聚合查询基础使用教程之度量(Metric)聚合 前言 在上上一篇中介绍了ElasticSearch实战系列三: Elas ...

  6. Python2.7错误处理FileNotFoundError报错NameError: name 'FileNotFoundError' is not defined

    错误信息如下: 原因是FileNotFoundError是python3.0中的写法,而Python2.7中应写为IOError.

  7. in和exists比较

    in是把外表和内表作hash 连接,而exists 是对外表作loop 循环,每次loop 循环再对内表进行查询. 一直以来认为exists 比in 效率高的说法是不准确的.如果查询的两个表大小相当, ...

  8. 达拉草201771010105《面向对象程序设计(java)》第七周学习总结

    达拉草201771010105<面向对象程序设计(java)>第七周学习总结 实验七继承附加实验 实验时间 2018-10-11 1.实验目的与要求 (1)进一步理解4个成员访问权限修饰符 ...

  9. jvm的运行参数

    1.我们为什么要对jvm做优化? 在本地开发环境中我们很少会遇到需要对jvm进行优化的需求,但是到了生产环境,我们可能将有下面的需求: 运行的应用“卡住了”,日志不输出,程序没有反应 服务器的CPU负 ...

  10. 前端如何真正晋级成全栈:腾讯 Serverless 前端落地与实践

    Serverless 是当下炙手可热的技术,被认为是云计算发展的未来方向,拥有免运维.降低开发成本.按需自动扩展等诸多优点.尤其是在前端研发领域,使用 Node 开发云函数,可以让前端工程师更加专注于 ...