首页 > 其他分享 >Go 快速入门指南 - goroutine

Go 快速入门指南 - goroutine

时间:2022-12-24 18:34:12浏览次数:43  
标签:入门 fmt goroutine go func time Go main

概述

goroutine 是 Go 程序并发执行的实体,对于初学者来讲,可以简单地将 ​​goroutine​​​ 理解为一个 ​​超轻量的线程​​。

当一个程序启动时,只有一个 goroutine 调用 main 函数,称为 ​​主 goroutine​​, 当 main 函数返回时, 所有 goroutine 都会终止 (不论其是否运行完成与否),然后程序退出。

语法规则

关键字 ​​go​​​ 启动一个 ​​goroutine​​ (可以理解为在后台运行一个函数), 需要注意的是: 使用 ​go​​ 启动的函数没有返回值

# 直接调用一个匿名函数
go func() { // 无参数
// do something ...
}

go func(x int, y bool ...) { // 有参数
// do something ...
}
# 调用一个已定义的函数
go foo() // 无参数

go bar(x int, y bool ...) // 有参数

例子

直接调用一个匿名函数

package main

import (
"fmt"
"time"
)

func main() {
// 3 个 goroutine 是并发运行的,所以顺序不一定是 1, 2, 3
// 读者可以多运行几次,看看输出结果

go func() {
fmt.Println("goroutine 1")
}()

go func() {
fmt.Println("goroutine 2")
}()

go func() {
fmt.Println("goroutine 3")
}()

// 这一行代码不可省略
// 如果省略掉,意味着主进程不等待 3 个 goroutine 执行完成就退出了,也就不会有 goroutine 的输出信息了
// 读者可以注释掉这行代码,然后运行看看输出结果
time.Sleep(1 * time.Second)
}

// $ go run main.go
// 输出如下, 3 个 goroutine 是并发运行的,顺序不一定,所以你的输出可能和这里的不一样
/**
goroutine 3
goroutine 1
goroutine 2
*/

调用 ​​time.Sleep()​​ 睡眠等待 3 个 goroutine 执行完成,虽然达到了演示效果,但是有很多潜在问题。更好的解决方案请看 waitgroup。

调用一个已定义的函数

package main

import (
"fmt"
"time"
)

func foo() {
fmt.Println("goroutine foo")
}

func bar() {
fmt.Println("goroutine bar")
}

func fooBar(s string) {
fmt.Printf("goroutine %s\n", s)
}

func main() {
// 3 个 goroutine 是并发运行的,所以顺序不一定是 1, 2, 3
// 读者可以多运行几次,看看输出结果

go foo()

go bar()

go fooBar("fooBar")

// 这一行代码不可省略
// 如果省略掉,意味着主进程不等待 3 个 goroutine 执行完成就退出了,也就不会有 goroutine 的输出信息了
// 读者可以注释掉这行代码,然后运行看看输出结果
time.Sleep(1 * time.Second)
}

// $ go run main.go
// 输出如下, 3 个 goroutine 是并发运行的,顺序不一定,所以你的输出可能和这里的不一样
/**
goroutine fooBar
goroutine foo
goroutine bar
*/

获取并发线程数量

​GOMAXPROCS()​​ 获得并发的线程数量,在 CPU 核大于 1 个的情况下,系统会尽可能调度等于核心数的线程并行运行。

package main

import (
"fmt"
"runtime"
)

func main() {
fmt.Printf("GOMAXPROCS = %d\n", runtime.GOMAXPROCS(0))
}

// $ go run main.go
// 输出如下,笔者的机器 CPU 是 8 核,你的输出可能和这里的不一样
/**
GOMAXPROCS = 8
*/

扩展阅读

  1. 1. 协程 - 维基百科 (https://zh.wikipedia.org/wiki/%E5%8D%8F%E7%A8%8B)
  2. 2. 线程 - 维基百科 (https://zh.wikipedia.org/wiki/%E7%BA%BF%E7%A8%8B)
  3. 3. Go 圣经 - 第 8 章 (https://book.douban.com/subject/27044219/)

Go 快速入门指南 - goroutine_Go

标签:入门,fmt,goroutine,go,func,time,Go,main
From: https://blog.51cto.com/u_15915979/5967440

相关文章

  • Go 快速入门指南 - 缓冲通道和非缓冲通道
    概述建议先阅读 goroutine 小节。Go箴言:不要通过共享内存来通信,而要通过通信来共享内存。​​goroutine​​​ 是Go程序并发执行的实体,​​channel(通道)​​​ ......
  • Go 快速入门指南 - 通道方向和关闭通道
    概述建议先阅读 阻塞通道 和 非阻塞通道 小节。在前面的两个小节中,为了最小化代码达到演示效果,省略了 ​​关闭通道​​ 的步骤,正确的做法应该是在通道使用完成后关......
  • Go 快速入门指南 - 遍历通道
    概述建议先阅读 range, 阻塞通道, 非阻塞通道 等小节。​​range​​ 除了可以遍历字符串、切片、数组等数据结构外,还可以遍历通道。语法规则和遍历其他数据结构不同,遍......
  • Go 快速入门指南 - 互斥锁和定时器
    互斥锁对于任一共享资源,同一时间保证只有一个操作者,这种方法称为 ​​互斥机制​​。关键字 ​​Mutex​​​ 表示互斥锁类型,它的 ​​Lock​​​ 方法用于获取锁,​​U......
  • django中间件
    django中间件相当于django框架的保安,只要数据过来必须经过中间件的校验。django中间件默认有7个。可以在setings内MIDDLEWARE里查看看着是字符串其实底层就是导模块的......
  • Gogs.02.构建本地仓库并上传到远程仓库
    01.通过VSCode构建一个Vue项目,npminitvue@latest配置参数并安装相关依赖  安装完成后,试运行一下,可以看到已还跑起来了; 02.本地仓构......
  • 使用PicGo+阿里云OSS实现md文档图片上传
    使用PicGo+阿里云OSS实现md文档图片上传这次给大家带来的是PicG0+阿里云Oss+typora的图床环境搭建,帮助大家提高工作效率+写博客速度!1.typora安装给大家一个链接:typora,打......
  • django中间件了解的三个方法、基于Django的插拔式设计、cookie与session简介、基于Dja
    目录Django中间件三个了解的方法1.process_view2.process_exception3.process_template_response基于Django中间实现功能的插拔式设计模拟编写一个消息通知功能(微信、qq、......
  • 红袖添香,绝代妖娆,Ruby语言基础入门教程之Ruby3基础数据类型(data types)EP02
    Ruby是强类型动态语言,即Ruby中一旦某一个对象被定义类型,如果不通过强制转换操作,那么它永远就是该数据类型,并且只有在Ruby解释器运行时才会检测对象数据类型,它的一切皆为对......
  • Go
    Chapter01编译器是全文翻译,解释器是实时翻译。1.环境搭建1.1MAC&Linux下载编译器:MAC:在golang.google.cn中点击DownloadGo,选择ApplemacOS即可,默认安装路径......