Jquery中文网 www.jquerycn.cn
Jquery中文网 >  后端编程  >  Go语言  >  正文 Go语言中Channel机制

Go语言中Channel机制

发布时间:2021-05-31   编辑:www.jquerycn.cn
jquery中文网为您提供Go语言中Channel机制等资源,欢迎您收藏本站,我们将为您提供最新的Go语言中Channel机制资源

前段时间尝试了一点 Google 的 Go 语言,感觉其很多特性还是不错的。Go 语言旨在结合传统编译型的静态语言和解释型的动态语言的优点,在其中找到一个平衡。从而打造一个既快速(编译执行),又方便编程的语言(动态语言往往语法简单快捷)。同时,Go 语言还具备丰富的特性以支持并发编程,这在现在多核非常普及的情况下,是很重要和强大的一个功能。

  Go 语言的并发特性主要有 goroutine, channel 等。

  goroutine - 可以大致理解为一种轻量级的线程(或微线程),它是一种“分配在同一个地址空间内的,能够并行执行的函数”。同时,它是轻量级的,不需要像分配线程那样分配独立的栈空间。所以理论上讲,我们可以很容易的分配很多个 goroutine, 让它们并发执行,而其开销则比多线程程序要小得多,从而可以让程序支持比较大的并发性。

  channel - 顾名思义,就是通道。通道的目的是用来传递数据。在一个通道上我们可以执行数据的发送(Send)和接受(Receive)操作。对于非缓冲的 channel 而言,Receive 方法执行时,会判断该通道上是否有值,如果没有就会等待(阻塞),直到有一个值为止。同样,在 channel 上有值,而尚未被一个 Receiver 接受的时候,Send 方法也会阻塞,直到 Channel 变空。这样,通过一个简单的机制就可以保证 Send 和 Receive 总是在不同的时间执行的,而且只有 Send 之后才能 Receive. 这样就避免了常规的多线程编程中数据共享的问题。正如 Go 语言的文档一句话所说:

  Do not communicate by sharing memory; instead, share memory by communicating.

  不要通过共享内存来沟通;而是通过沟通来共享内存。

  在常规的多线程编程里,我们总是定义好一些类变量,如果这些变量有可能被多个线程同时访问,那么就需要加锁。这样带来了一定的编程复杂性,如果代码写的稍有bug,则会导致读/写到错误的值。

  而通过 channel 来沟通,我们得到了一个更为清晰的沟通方式。两个线程(或者 goroutine)要读写相同的数据,则创建一个通道,双方通过对这个通道执行 Send / Receive 的操作来设值或取值即可,相对而言,比较不容易出错。

<<GO语言简介下>>

http://www.20ju.com/content/V227275.htm


到此这篇关于“Go语言中Channel机制”的文章就介绍到这了,更多文章或继续浏览下面的相关文章,希望大家以后多多支持JQ教程网!

您可能感兴趣的文章:
Go 语言 select 语句
Go语言中Channel机制
Go语言并发--传统锁与channel的选择
Go 语言为什么这么快,带你详细了解Golang CSP并发模型
Go语言学习3----Go语言特色
go channel 使用及机制流程汇总
Golang学习小结、从入门到精通资料汇总
GoLang之协程
Go语言发展历史、核心、特性及学习路线
浅谈 Go 语言 select 的实现原理

[关闭]