1,go包可导出的函数或者变量首字母必须大写
2,接口类型的变量可以保存任何实现了这些方法的 值 <此处为值若为绑定指针实现的方法则不可以>
3,引入一个包默认执行该包目录下所有init函数,一般写一个init就可以了
4,interface转struct v,ok = interface.(struct) if ok{...}
5,:= 是声明 = 是赋值 使用:=必须至少有一个新变量 否则既然前面声明了则用=即可
6,new是一个预声明的函数,而不是一个关键字 new(T) 返回*T 指向类型T的指针
7,v,ok = m[key] //map查询 v,ok = x.(T) // 类型断言 v,ok = <-ch // 通道接收
8,go包初始化:包中任何文件可以包含任意数量的init函数,init函数会按照他们的声明顺序执行
9,make只能创建slice、map和channel,并且返回一个有初始值(非零)的T类型,而不是*T
10,new(T)分配了零值填充的T类型的内存空间,并且返回其地址,即一个*T类型的值
11,Go语言中channel,slice,map这三种类型的实现机制类似指针,所以可以直接传递,而不用取地址后传递指针。(注:若函数需改变slice的长度,则仍需要取地址传递指针,map则不需要)
12,虽然一个package里面可以写任意多个init函数,但这无论是对于可读性还是以后的可维护性来说,我们都强烈建议用户在一个package中每个文件只写一个init函数。
13,import _"github.com/ziutek/mymysql/godrv"。 _ 操作其实是引入该包,而不直接使用包里面的函数,而是调用了该包里面的init函数。
14,panic,recover都是内建函数,panic可以自己调用产生,也可以由系统错误产生,recover仅在延迟函数中有效。如果当前的goroutine陷入panic状态,调用recover可以捕获到panic的输入值,并且恢复正常的执行。
15,struct中的匿名字段和struct中名称相同时,最外层的优先访问 比如studen中有匿名字段human,他们中都有name时 s.name先访问的是外层的name
16,time.Now().Format("2006-01-02 15:04:05") 换算成字符串的时间格式
17,找不到包或者包被移到另一个地方解决方案 如
mkdir -p $GOPATH/src/golang.org/x
cd $GOPATH/src/golang.org/x
git clone https://github.com/golang/sys.git
18,s5 := append(s[:2], s[3:]...) slice 删除索引为2的元素
19,go调用命令
假如之前执行报错的语句为:
cmd := exec.Command("echo", "'helloworld!'")
out, err := cmd.Output()
那么改为:
c := "echo hello world"
cmd := exec.Command("sh", "-c", c)
out, err := cmd.Output()
即可!
20,vscode go:cannot find main module;see 'go help modules'报错无法运行
设置环境变量GO111MODULE=auto
21,json文件注释 使用 "_" : "注释"
https://www.cnblogs.com/zengyjun/p/10218088.html
22,当把json解析到interface{}时 , 对应的真正类型,可先都转成字符串处理,
23,json一些问题
JSON输出的时候必须注意,只有导出的字段(首字母是大写)才会被输出,如果修改字段名,那么就会发现什么都不会输出,所以必须通过struct tag定义来实现。
针对JSON的输出,我们在定义struct tag的时候需要注意的几点是:
- 字段的tag是"-",那么这个字段不会输出到JSON - tag中带有自定义名称,那么这个自定义名称会出现在JSON的字段名中
- tag中如果带有"omitempty"选项,那么如果该字段值为空,就不会输出到JSON串中
- 如果字段类型是bool, string, int, int64等,而tag中带有",string"选项,那么这个字段在输出到JSON的时候会把该字段对应的值转换成JSON字符串
参考:https://www.cnblogs.com/taoshihan/p/12960449.html
24,go中没有++ -- 只有 += -=
25,go中没有指针运算,