Google资深工程师深度讲解Go语言-Goroutine并发编程(九)[通俗易懂]

Google资深工程师深度讲解Go语言-Goroutine并发编程(九)

大家好,又见面了,我是全栈君。

一.协程 coroutine

  • 轻量级”线程“:并发执行一些任务,
  • 非抢占式多任务处理,由协程主动交出控制权:
  • 编译器/解释器/虚拟机层面的多任务
  • 多个协程可能在一个或多个线程上运行:由调度器决定

线程任何时候都可以被操作系统切换,抢占式任务处理,没有控制权,随时被操作系统切换.

执行go文件: go run  goroutine.go   

检测数据访问的冲突  go run -race goroutine.go

Google资深工程师深度讲解Go语言-Goroutine并发编程(九)[通俗易懂]

package main

import (
	"fmt"
	"runtime"
	"time"
)

func main() {
	var sum [10]int
	for i := 0; i < 10; i++ { //1000个并发执行
		go func(ii int) {
			for {
				//fmt.Printf("Hello from goroutine %d \n", a)
				sum[ii]++
				runtime.Gosched() //手动交出控制权
			}
		}(i)
	}
	time.Sleep(time.Microsecond)
	fmt.Println(sum)
}

二.go语言的调度器

python中协程

  • 使用yield关键字实现协程
  • python3.5加入了async def 对协程原生支持

go语言中协程 :

goroutine的定义

  • 任何函数只需要加上go就能送给调度器运行
  • 不需要在定义时区分是否是异步函数
  • 调度器在合适的点进行切换
  • 使用-race来检测数据访问冲突

goroutine可能的切换点

  • I/o,select
  • channel
  • 等待锁
  • 函数调用(有时)
  • runtime.Gosched()
  • 只是参考,不能保证切换,不能保证在其他地方不切换

子程序是协程的一个特例

Google资深工程师深度讲解Go语言-Goroutine并发编程(九)[通俗易懂]

___go_build_ 25.6  00:15.06 8/2 总线程8个,活动线程2个,不会超过电脑物理核数     

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/111708.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • c语言qq密码程序设计,【转】C语言实现QQ密码大盗

    c语言qq密码程序设计,【转】C语言实现QQ密码大盗该楼层疑似违规已被系统折叠隐藏此楼查看此楼【转】C语言实现QQ密码大盗一般的盗密码的软件的软件都是通过监视键盘来获得密码,这样操作比较方便,但是这样也存在一定问题,密码有的时候不是很准确,因为有的人输入密码并不是从前到后输入,当然这样的人也是少数,盗密码嘛,当然去得到那些比较粗心的人的密码!通过安装钩子来监视QQ登陆界面就是获得密码的方法,在安装前得先找到登陆窗口的句柄,当钩子安装后,记录键盘…

    2022年7月20日
    18
  • MySQL EXPLAIN type类型说明[通俗易懂]

    MySQL EXPLAIN type类型说明[通俗易懂]EXPLAIN执行计划中type字段分为以下几种:ALL    INDEX    RANGE    REF    EQ_REF    CONST,SYSTEM    NULL自上而下,性能从最差到最好 type=ALL,全表扫描,MYSQL扫描全表来找到匹配的行(因为film表中rating不是索引)mysql&gt;explainexten…

    2022年10月10日
    2
  • Shell常用命令大全[通俗易懂]

    Shell常用命令大全[通俗易懂]嵌入式开发用的最多就是Shell命令,Shell命令是所有的Linux系统发行版所通用的,并不是说我在Ubuntu下学会了Shell命令,换另外一个Linux发行版操作系统以后就没用了,所以学习Shell命令非常有必要。1、目录信息查看命令文件浏览是最基本的操作了,Shell下文件浏览命令为ls,格式如下:ls[选项][路径]Is命令主要用于显示指定目录下的内容,列出指定目录下包含的所有的文件以及子目录,它的主要参数有:-a显示所有的文件以及子目录,包括以“”开头的隐藏文件。-l

    2022年10月18日
    3
  • Python该怎么入门?Python入门教程(非常详细)「建议收藏」

    Python该怎么入门?Python入门教程(非常详细)「建议收藏」Python要学多久可以学会,达到精通呢?任何知识都是基础入门比较快,达到通晓的程序是需求时日的,这是一个逐渐激烈的进程。通晓任何一门编程语言,都需求通过大量的实践来积累经验,解决遇到的各种疑难问题,看别人的源码,分享自己的分码的这个进程,才能够通晓Python的方方面面。一个对Python程序能算的上通晓的程序员,对相同一个问题,他知道很多种解决问题的方法,并能从中挑选最有功率的方法!…

    2022年8月29日
    4
  • temptation系列_dramatical murder攻略

    temptation系列_dramatical murder攻略投影投影是JMESPath的关键特性之一。它允许您将表达式应用于元素集合。有五种投影:列表投影切片投影对象投影展平投影过滤投影处理投影需要注意的点投影分为两个步骤。左侧(LHS)创建一

    2022年7月28日
    5
  • zoj 3822 Domination (可能性DP)

    zoj 3822 Domination (可能性DP)

    2021年12月17日
    37

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号