Go语言怎么天然支持并发 go语言并发之道 pdf( 三 )


go里面的强制转换是将值复制过去,所以在数据量的时候有比较高的运行代价
Go CSP并发模型Go的CSP并发模型
Go实现了两种并发形式 。第一种是大家普遍认知的:多线程共享内存 。其实就是Java或者C++等语言中的多线程开发 。另外一种是Go语言特有的,也是Go语言推荐的:CSP(communicating sequential processes)并发模型 。
CSP 是 Communicating Sequential Process 的简称,中文可以叫做通信顺序进程 , 是一种并发编程模型,由 Tony Hoare 于 1977 年提出 。简单来说,CSP 模型由并发执行的实体(线程或者进程)所组成,实体之间通过发送消息进行通信,这里发送消息时使用的就是通道,或者叫 channel 。CSP 模型的关键是关注 channel,而不关注发送消息的实体 。Go 语言实现了 CSP 部分理论。
“不要以共享内存的方式来通信,相反,要通过通信来共享内存 。”
Go的CSP并发模型,是通过goroutine和channel来实现的 。
goroutine 是Go语言中并发的执行单位 。其实就是协程 。
channel是Go语言中各个并发结构体(goroutine)之前的通信机制 。通俗的讲 , 就是各个goroutine之间通信的”管道“,有点类似于Linux中的管道 。
Channel
Goroutine
Go语言有什么优势?GO语言的优势:可直接编译成机器码,不依赖其他库,glibc的版本有一定要求,部署就是扔一个文件上去就完成了 。静态类型语言 , 但是有动态语言的感觉 , 静态类型的语言就是可以在编译的时候检查出来隐藏的大多数问题,动态语言的感觉就是有很多的包可以使用,写起来的效率很高 。语言层面支持并发,这个就是Go最大的特色,天生的支持并发 , 我曾经说过一句话 , 天生的基因和整容是有区别的 , 大家一样美丽 , 但是你喜欢整容的还是天生基因的美丽呢?Go就是基因里面支持的并发 , 可以充分的利用多核,很容易的使用并发 。内置runtime , 支持垃圾回收,这属于动态语言的特性之一吧,虽然目前来说GC不算完美,但是足以应付我们所能遇到的大多数情况 , 特别是Go1.1之后的GC 。简单易学,Go语言的作者都有C的基因 , 那么Go自然而然就有了C的基因,那么Go关键字是25个,但是表达能力很强大,几乎支持大多数你在其他语言见过的特性:继承、重载、对象等 。丰富的标准库,Go目前已经内置了大量的库,特别是网络库非常强大,我最爱的也是这部分 。内置强大的工具,Go语言里面内置了很多工具链,最好的应该是gofmt工具,自动化格式化代码,能够让团队review变得如此的简单,代码格式一模一样,想不一样都很困难 。跨平台编译,如果你写的Go代码不包含cgo,那么就可以做到window系统编译linux的应用 , 如何做到的呢?Go引用了plan9的代码,这就是不依赖系统的信息 。Go语言这么多的优势,你还不想学吗?我记得当时我看的是黑马程序员的视频,我对他们视频的印象就是通俗易懂,就是好!
【Go语言怎么天然支持并发 go语言并发之道 pdf】Go语言怎么天然支持并发的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于go语言并发之道 pdf、Go语言怎么天然支持并发的信息别忘了在本站进行查找喔 。

推荐阅读