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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Perl 正则表达式替换

    Perl 正则表达式替换文本处理中经常需要将字符串中的某些字符替换后再进行处理,以下是新发现的非常方便的方法,充分发挥了Perl正则表达式的威力。$str=”thisisatesting”;$str=~s/(/w+)(/w+)/$2$1/;print$str;————————————OUTPUT:isthisatesti

    2022年5月6日
    115
  • 常见的路由协议「建议收藏」

    常见的路由协议「建议收藏」常见的路由协议可以分为两种类型一、内部网关协议内部网关协议(IGP:InteriorGatewayProtocol),适用于单个ISP的统一路由协议的运行,一般由一个ISP运营的网络位于一个AS(自治系统)内,有统一的ASnumber(自治系统号),用来处理内部路由。RIP、IGRP(Cisco私有协议)、EIGRP(Cisco私有协议)、OSPF、IS-IS等都是内部网关协议。1、…

    2022年10月22日
    0
  • 利用NFS client provisioner动态提供Kubernetes后端存储卷–安装指南与实践[通俗易懂]

    利用NFS client provisioner动态提供Kubernetes后端存储卷–安装指南与实践[通俗易懂]利用NFS client provisioner动态提供Kubernetes后端存储卷–安装指南与实践

    2022年4月21日
    148
  • 【树莓派】一根网线将树莓派4B直连笔记本电脑的方法

    【树莓派】一根网线将树莓派4B直连笔记本电脑的方法当我们为新买来的树莓派刷上系统之后,如何将树莓派和笔记本电脑连接到同一网络使用SSH工具登录树莓派呢?相信大多数人的做法是将树莓派连接到路由器上,然后通过SSH工具(putty,SecureCRT等)远程登录,但如果你没有显示器和HDMI线,那么,这里介绍如何使用一根网线来连接树莓派。准备材料1、树莓派2、已经刷入系统的SD卡3、一根网线4、一个已经连接互联网的笔记本5、usb网口…

    2022年6月5日
    39
  • 一篇文章弄懂Java多线程基础和Java内存模型

    一篇文章弄懂Java多线程基础和Java内存模型文章目录一、多线程的生命周期及五种基本状态二、Java多线程的创建及启动1.继承Thread类,重写该类的run()方法2.通过实现Runnable接口创建线程类3.通过Callable和Future接口创建线程三、Java内存模型概念四、内存间的交互操作五、volatile和synchronized的区别写在前面:提起多线程大部门同学可能都会皱起眉头不知道多线程到底是什么、什么时候可以用到、用…

    2022年5月22日
    36
  • ubuntu学习的简单笔记

    l vi编辑器开发步骤A)输入 vi Hello.javaB) 输入 i 插入模式。C)输入 冒号。【保存退出:wq】【退出

    2021年12月28日
    45

发表回复

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

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