Go 并发与并行的理解

本文讲述了Go语言中并发和并行的概念,介绍了goroutines和channels在并发编程中的作用,以及两者之间的区别。通过一个简单的for循环与goroutine的例子,说明了并发执行的特点,指出并行性受运行时环境和系统负载影响。
摘要由CSDN通过智能技术生成

在Go语言(Golang)中,并发(Concurrency)和并行(Parallelism)是两个既有联系又有所区别的概念

并发(Concurrency)

并发指的是在一段时间内,多个任务能够开始、执行和完成,这些任务在宏观上看起来是同时进行的,尽管在微观层面上它们可能并不是真正的同时执行。Go语言通过goroutines(轻量级线程)和channels(用于goroutines间通信的安全通道)来支持高效率的并发编程。并发的重点在于任务的组织和管理,使得即使在单个CPU核心上,也能通过时间切片和任务调度,给予用户多个任务同时进行的错觉。

并行(Parallelism)

并行则是指在物理上或逻辑上的多个处理器(或多核CPU)同时执行多个任务。当程序能够充分利用多核处理器的多个核心,使得不同的任务或任务的部分确实同时在不同的处理器上执行,这就是并行。Go语言的运行时能够自动利用多核处理器,使得当有足够的goroutines需要运行时,它们可以被分配到不同的CPU核心上并行执行,从而提升程序的执行效率。

关系与区别

  • 区别:并发关注的是任务的执行方式和任务间的协作,能够在单核或多核环境下工作,不保证任务绝对同时执行。而并行关注的是任务的实际同时执行,需要多核环境来实现。
  • 联系:并发是并行的基础,没有并发就没有并行。并发使得程序能够在逻辑上分解为多个独立执行的单元,而并行则是在硬件层面实现这些单元的同时执行,从而达到更高的性能。 
for i := 1; i <= 10; i++ {

	go func() {
		fmt.Println("123")
	}()
}

 这段代码展示了Go语言中并发的特性。for循环与通过go关键字启动的goroutines之间是并发执行的。具体分析如下:

  • 并发性: 当for循环每次迭代时,它都会启动一个新的goroutine并通过go func() {...}()表达式。这意味着循环继续进行下一次迭代时,刚启动的goroutine几乎立刻开始执行,无需等待前一个goroutine完成。因此,这些goroutine的执行是并发的——它们的执行在时间上重叠,不过实际的执行顺序取决于Go运行时的调度策略和可用的处理器核心。

  • 并行性: 是否并行执行(即是否同时在多个处理器核心上执行)则取决于运行时环境和当前系统的负载。如果系统有多个处理器核心且goroutines的数量足够多以至于它们不能全部在一个核心上高效执行,Go的调度器可能会将这些goroutine分布在不同的核心上并行执行。然而,对于这段特定的代码,由于goroutine内的工作非常轻(仅打印一个空字符串),并行收益不大,甚至可能全部在一个核心上顺序快速执行完,因为启动goroutine和打印操作都非常快。

总结来说,这段代码展示了并发执行,而并行性取决于运行时的具体情况,但就这个简单的示例而言,并行效果可能不明显。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值