并发指的是多个任务被(一个)cpu 轮流切换执行,在 Go 语言里面主要用 goroutine (协程)来实现并发,类似于其他语言中的线程(绿色线程)。
语法
go f(x, y, z)
具体例子
首先我们看一个例子:
packagemainimport("log""time")funcdoSomething(idint){log.Printf("before do job:(%d) \n",id)time.Sleep(3*time.Second)log.Printf("after do job:(%d) \n",id)}funcmain(){doSomething(1)doSomething(2)doSomething(3)}
2018/03/16 12:13:20 before do job:(1)
2018/03/16 12:13:23 after do job:(1)
2018/03/16 12:13:23 before do job:(2)
2018/03/16 12:13:26 after do job:(2)
2018/03/16 12:13:26 before do job:(3)
2018/03/16 12:13:29 after do job:(3)
package main
import (
"log"
"time"
)
func doSomething(id int) {
log.Printf("before do job:(%d) \n", id)
time.Sleep(3 * time.Second)
log.Printf("after do job:(%d) \n", id)
}
func main() {
go doSomething(1)
go doSomething(2)
go doSomething(3)
}
package main
import (
"log"
"time"
)
func doSomething(id int) {
log.Printf("before do job:(%d) \n", id)
time.Sleep(3 * time.Second)
log.Printf("after do job:(%d) \n", id)
}
func main() {
go doSomething(1)
go doSomething(2)
go doSomething(3)
time.Sleep(4 * time.Second)
}
2018/03/16 12:24:23 before do job:(2)
2018/03/16 12:24:23 before do job:(1)
2018/03/16 12:24:23 before do job:(3)
2018/03/16 12:24:26 after do job:(3)
2018/03/16 12:24:26 after do job:(2)
2018/03/16 12:24:26 after do job:(1)
package main
import (
"log"
"sync"
"time"
)
func doSomething(id int, wg *sync.WaitGroup) {
defer wg.Done()
log.Printf("before do job:(%d) \n", id)
time.Sleep(3 * time.Second)
log.Printf("after do job:(%d) \n", id)
}
func main() {
var wg sync.WaitGroup
wg.Add(3)
go doSomething(1, &wg)
go doSomething(2, &wg)
go doSomething(3, &wg)
wg.Wait()
log.Printf("finish all jobs\n")
}
2018/03/16 13:56:09 before do job:(1)
2018/03/16 13:56:09 before do job:(3)
2018/03/16 13:56:09 before do job:(2)
2018/03/16 13:56:12 after do job:(1)
2018/03/16 13:56:12 after do job:(2)
2018/03/16 13:56:12 after do job:(3)
2018/03/16 13:56:12 finish all jobs
package main
import (
"fmt"
"time"
)
func main() {
for i := 0; i < 3; i++ {
go func() {
fmt.Println(i)
}()
}
time.Sleep(1 * time.Second)
}
3
3
3
package main
import (
"fmt"
"time"
)
func main() {
for i := 0; i < 3; i++ {
go func(v int) {
fmt.Println(v)
}(i)
}
time.Sleep(1 * time.Second)
}