go 编程小tips
1,if条件语句注意事项:条件语句不需要使用括号将条件包含起来 () ; 无论语句体内有几条语句,花括号 {} 都是必须存在的; 左花括号 { 必须与 if 或者 else 处于同一行; 在 if 之后,条件语句之前,可以添加变量初始化语句,使用 ; 间隔;
2,slice可直接使用append对其进行添加元素如append(slice,slice对应元素),也可直接在slice中添加slice,不过此时写法为append(slice1,slice2…),其中slice2后有…表示将slice2打散成元素后再添加到slice1中
3,break可以后面加标签,表示跳出对应标签的循环。如break Look表示跳出外层循环。
Loop: for i := 0; i < 5; i++ { for j := 0; j < 5; j++ { if j >= 4 { break Loop } } }
4,go中可使用不定参数,其使用方法如下:“…type”表示具有不定个type类型的参数,不定参数实质上是一个slice类型,故可以使用range对其参数进行取值。如下例子。
func myfunc(args ...int) { for _, arg := range args { fmt.Println(arg) } }
5.go语言中没有构造函数的概念,对象的构建通常交给一个全局构建函数来构建,通常以NewXXX来命名,表示构造函数。如
func NewRect(x, y, width, height float64) *Rect { return &Rect{x, y, width, height} }
6.go语言中对于堆和栈的内存分配没有严格区分,在go中返回一个局部变量的地址是绝对没有问题的,变量关联的存储在函数返回后依然存在.(注:尤其对由C/C++转过来的程序员,开始肯定不是很适应,但是go这种内存分配方式解放了程序员,使得程序员能够专注做事情,而不用花费太多的时间在堆和栈的内存分配上).更直接的说,在go语言中,如果一个局部变量在函数返回后仍然被使用,那么这个变量会在堆heap,而不是栈stack中进行内存分配.详情参考How do I know whether a variable is allocated on the heap or the stack?
7. golang允许多个返回值,并且返回值有两种形式,一种只是指定类型,还有一种指定返回值名称.如下所示:
func SumAndProduct(a, b int) (int, int) { return a+b, a*b } func SumAndProduct(a, b int) (add int, Multiplied int) { add = a + b; Multiplied = a * b; return }当定义函数时指定返回参数变量时,可以直接返回而不用带变量名。注意:如果命令的返回参数跟函数代码块中的变量同名,他会被隐藏,此时需显示return返回结果;还有就是显式return会先修改命名返回值,然后再执行defer延迟语句。由于会出现函数中临时变量名和指定返回值名字冲突的情况,所以建议使用不指定返回值名称的形式.
8.参数之变参:
golang支持变参,变量中所有参数的类别必须是同一种,且必须是最后一个形参。函数内获取变参为一个slice。函数声明为:func FuncName(args ...int) { } args ...int 告诉go这个函数接受变参参数。 使用如sum(x[2:6]...)
9. defer 与return执行顺序
当函数执行到最后时,先执行defer语句,然后才执行return语句.所以可以利用这个来进行资源安全关闭,解加锁,记录执行情况等。defer是采用先进后出的模式的,这种情形与栈的情况一致。注意:定义的defer延迟操作,如有提供参数会发生值的拷贝,尽管这些函数在退出时才执行,但所使用的参数是在定义时就进行拷贝,拷贝的原则和变量的赋值原则一个,slice,map,channel是指针拷贝.如下例子:
当函数执行到最后时,先执行defer语句,然后才执行return语句.所以可以利用这个来进行资源安全关闭,解加锁,记录执行情况等。defer是采用先进后出的模式的,这种情形与栈的情况一致。注意:定义的defer延迟操作,如有提供参数会发生值的拷贝,尽管这些函数在退出时才执行,但所使用的参数是在定义时就进行拷贝,拷贝的原则和变量的赋值原则一个,slice,map,channel是指针拷贝.如下例子:
<span style="color:#000000;">package main import ( "fmt" ) func main() { x := 1 defer func(a int) { //直接将x=1赋值给a,虽然他在后面才执行. fmt.Println("a=", a) }(x) defer func() { fmt.Println("x=", x) //经过x++后,x值变为2 }() x++ } 运行结果: x= 2 a= 1 </span>
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步