go 语言具有天生的并发优势,轻量级线程(goroutine) 和通道(channel) 是Go 语言实现并发模式的重要基础。
1.go怎么实现并发?
2.go 并发怎么实现同步?
格式:
go 函数名(参数列表)
案例一
实现多线程并发
package main
import (
"fmt"
"time"
)
func running() {
var times int
// 构建一个无限循环
for {
times++
fmt.Println("tick ", times)
// 演示1秒
time.Sleep(time.Second)
}
}
func main() {
// 并发执行程序
go running()
time.Sleep(time.Second * 2)
}
运行结果:
tick 1
tick 2
问题二案例
Go 应用可以使用通道进行多个goroutine间的数据交换。
package main
import (
"fmt"
)
func printer(c chan string) {
//开始无限循环等待数据
for {
// 从channel 中获取一个数据
data := <-c
//将 0 视为数据结束
if data == "" {
break
}
//打印数据
fmt.Println(data)
}
//通知main结束循环 (没有数据了)
c <- ""
}
func main() {
// 创建一个channel
c := make(chan string)
// 并发执行printer, 传入channel
go printer(c)
for i := 0; i < 2; i++ {
c <- "I am working"
}
// 通知并发的printer结束循环(没有数据了)
c <- ""
//等待printer 结束
<-c
}
运行结果:
I am working
I am working
通过使用原子访问(atomic包),互斥锁(sync.Mutex),以及等待组(sync.WaitGroup)处理数据访问异常竞争。