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 =

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

cdGOPATH/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

文章来源于互联网,如有雷同请联系站长删除:go开发遇到的问题

发表评论