Go世界里,每个并发执行的活动成为goroutine。css
经过建立goroutine,就能够实现并行运算,十分方便。
算法
若是有函数f(),那么:markdown
f():调用函数f(),而且等待它返回并发
go f():新建一个调用f()的goroutine,不等待函数
Go语言程序:spa
// fib project main.go package main import ( "fmt" "time" ) func main() { go spinner(1000 * time.Millisecond) const n = 46 fibN := fib(n) // slow fmt.Printf("\rFibonacci(%d) = %d\n", n, fibN) } func spinner(delay time.Duration) { for { for i, r := range "abcd" { fmt.Printf("%d: %c\n", i, r) time.Sleep(delay) } } } func fib(x int64) int64 { if x < 2 { return x } return fib(x-2) + fib(x-1) }
运行结果:.net
0: a 1: b 2: c 3: d 0: a 1: b 2: c 3: d 0: a 1: b 2: c 3: d 0: a 1: b 2: c 3: d 0: a 1: b 2: c 3: d 0: a 1: b 2: c 3: d 0: a Fibonacci(46) = 1836311903
程序说明:code
1.函数spinner()是个死循环,循环输出字符串中的一个字符,而后进入睡眠状态1秒钟blog
2.函数fib()是递归算法的计算程序,很是慢,尤为是调查用时代入的参数是46,实际运行实际大概是25秒递归
3.函数main()结束时,会强制终结全部的goroutine,而后退出程序