美文网首页
Golang并发、协程

Golang并发、协程

作者: 水无寒 | 来源:发表于2018-10-31 00:05 被阅读0次

并行(parallel):指在同一时刻,有多条指令在多个处理器上同时执行。

并发(concurrency):指在同一时刻只能有一条指令执行,但多个进程指令被快速的轮换执行,使得在宏观上具有多个进程同时执行的效果,但在微观上并不是同时执行的,只是把时间分成若干段,使多个进程快速交替的执行。

goroutine

goroutine是比线程更小的工作单元,go语言内部实现了goroutine之间的内存共享,它比thread更易用、更高效、更轻便。

创建goroutine

只需要在函数调用语句前添加"go"关键字,就可以创建并发执行单元。当一个程序启动时,其主函数即在一个单独的goroutine中运行,称为main goroutine。当主协程结束的时候,子协程也会自动结束。

Gosched

runtime包的方法,让出时间片,让其它协程先执行

Goexit

runtime 包的方法,终止所在协程

GOMAXPROCS

runtime包的方法,获取最大核心数,指定使用核心数

channel

channel是内置的数据结构,用于读取发送数据,无数据时,读取数据会阻塞,设置了最大写入数据时,写满capacity个元素时,写入阻塞。

channel创建

make(chan Type)

make(chan Type, capacity)

channel读写

ch <- 666

<- ch

无缓冲的channel

make(chan Type)

make(chan Type,0)

有缓冲的channel

是一种在被接受前能存储一个或多个值得channel

make(chan Type,3)

单向channel

var send chan<- int

var receiver <-chan int

相关文章

  • Golang并发、协程

    并行(parallel):指在同一时刻,有多条指令在多个处理器上同时执行。 并发(concurrency):指在同...

  • Golang的并发编程

    Golang中的并发编程 Golang语言中,并发使用的协程的机制,实现起来也是十分的方便,使用go关键字即可。 ...

  • 【Golang】通道channel

    Java的并发:基于线程Golang的并发:基于协程goroutine 并发会导致资源竞争:加锁防止资源竞争的三种...

  • golang 协程并发编程

  • Go 并发编程:Goroutine常见应用范式

    一、多独立协程并发——worker分工模式 并发协程独立运行且互不通信,主协程等待处理独立子协程的结果 并发编程有...

  • golang的理解

    golang 1、天然的并发优势,特别适合 IO 密集应用(goroutine 有栈协程2k,OS thread是...

  • go channel详解之源码分析

    作为golang并发编程思想的重要组成,channel(通道)非常重要,和goroutine(go协程)一起使用,...

  • 第六天

    一、并发编程 并发与并行(并发时间片轮询)资源竞争 1、goruntine协程 主协程退出了其他协程也跟着退出 主...

  • 浅谈GoLang协程

    GoLang协程 学习golang也有一段时间了,这里讲一下自己对golang协程的使用理解,golang很多人都...

  • Golang并发调度模型解析

    学习golang,必然绕不开并行与并发这样的概念,作为golang的一大卖点,轻量级的协程应该是我们要理解的,包括...

网友评论

      本文标题:Golang并发、协程

      本文链接:https://www.haomeiwen.com/subject/hstvtqtx.html