Go语言圣经 - 第8章 Goroutines 和 Channels - 8.1 Goroutines

第8章 Goroutines 和 Channels

Go语言中的并发程序可以用两种手段来实现:goroutine 和 channel,其支持顺序通信进程,或被简称为CSP,CSP是一种并发编程模型,在这种并发编程模型中,值会在不同运行实例中传递,第二个手段便是多线程共享内存

8.1 Goroutines

在Go语言中,每一个并发的执行单元叫作一个goroutine。当一个程序启动时,其主函数在一个单独的goroutine中运行,我们叫它main goroutine。新的goroutine会用go语句创建,即在函数或者方法前加上go,go语句会使其语句中的函数在一个新建的goroutine中运行,而go语句本身也会迅速完成

go f()

让我们写个函数看看

func main() {
	go spinner(100 * time.Millisecond)
	const n = 45
	fibN := fib(n)
	fmt.Printf("\rFibonacci(%d) = %d\n", n, fibN)
}

func spinner(delay time.Duration) {
	for {
		for _, r := range '-\|/' {
			fmt.Printf("\r%c", r)
			time.Sleep(delay)
		}
	}
}
func fib(x int) int {
	if x < 2 {
		return x
	}
	return fib(x-1) + fib(x-2)
}

函数运行会在几秒后出现结果

Fibonacci(45) = 1134903170

然后主函数返回,除了从主函数退出或者直接终止程序外,没有其它编程方法能够让一个goroutine打断另一个的执行,但是之后可以看到一种方式来实现这个目的,通过goroutine之间的通信来让一个goroutine请求其他的goroutine,并让被请求的goroutine自行结束执行

注意,fib函数和spinner函数是同时执行的

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值