tomoya06 / web-developer-guidance

Actually it's just a notebook for keeping down some working experience.
4 stars 0 forks source link

GoLang 语法特性 #41

Open tomoya06 opened 2 years ago

tomoya06 commented 2 years ago

近期学习GoLang语法,只收集一些GoLang里比较特别的语法能力。

Go语言圣经确实不错,开篇先来几个小Demo练手,而不是硬生生地讲语法。

学英语斋背单词是没用的,你得说。 ——我,2021.11.02

defer

摘自Go语言圣经 - deferred函数

你只需要在调用普通函数或方法前加上关键字defer,就完成了defer所需要的语法。当执行到该条语句时,函数和参数表达式得到计算,但直到包含该defer语句的函数执行完毕时,defer后的函数才会被执行,不论包含defer语句的函数是通过return正常结束,还是由于panic导致的异常结束。你可以在一个函数中执行多条defer语句,它们的执行顺序与声明顺序相反。

defer语句经常被用于处理成对的操作,如打开、关闭、连接、断开连接、加锁、释放锁。通过defer机制,不论函数逻辑多复杂,都能保证在任何执行路径下,资源被释放。

补充:可以通过匿名函数读取到函数返回值,并修改返回结果。

tomoya06 commented 2 years ago

goroutine 协程

摘自Go语言圣经 - goroutine

如果你使用过操作系统或者其它语言提供的线程,那么你可以简单地把goroutine类比作一个线程。

当一个程序启动时,其主函数即在一个单独的goroutine中运行,我们叫它main goroutine。

执行时序

主函数返回时,所有的goroutine都会被直接打断,程序退出。除了从主函数退出或者直接终止程序之外,没有其它的编程方法能够让一个goroutine来打断另一个的执行。

但是之后可以看到一种方式来实现这个目的,通过goroutine之间的通信来让一个goroutine请求其它的goroutine,并让被请求的goroutine自行结束执行。

channel

来自Golang语言圣经 - Channels

如果说goroutine是Go语言程序的并发体的话,那么channels则是它们之间的通信机制。一个channel是一个通信机制,它可以让一个goroutine通过它给另一个goroutine发送值信息。

ch := make(chan int) // ch has type 'chan int'

ch <- x  // a send statement
x = <-ch // a receive expression in an assignment statement
<-ch     // a receive statement; result is discarded

close(ch)

一个基于无缓存Channels的发送操作将导致发送者goroutine阻塞,直到另一个goroutine在相同的Channels上执行接收操作,当发送的值通过Channels成功传输之后,两个goroutine可以继续执行后面的语句。

反之,如果接收操作先发生,那么接收者goroutine也将阻塞,直到有另一个goroutine在相同的Channels上执行发送操作。

以最简单方式调用make函数创建的是一个无缓存的channel,但是我们也可以指定第二个整型参数,对应channel的容量。如果channel的容量大于零,那么该channel就是带缓存的channel。

ch := make(chan string, 3)