Go语言入门(22)-goroutine

在Go中,独立的任务叫做goroutine。虽然goroutine与其他语言中的协程、进程、线程都有相似之处,但goroutine和它们并不完全相同。goroutine创建效率非常高,并且Go能直截了当地协同多个并发(concurrent)操作

在某些语言中,将顺序式代码转化为并发式代码需要做大量修改。在Go里,无需修改现有顺序式地代码,就可以通过goroutine一并发地方式运行任意数量的任务。

启动goroutine的方法:只需在调用前面加一个go关键字。

Go 复制代码
package main

import (
    "fmt"
    "time"
)

func main() {
    go sleepyGopher()//分支路线
    //time.Sleep(4 * time.Second)//主路线
}

func go sleepyGopher(){
    time.Sleep(3 * time.Second)
    fmt.Println("...snore...")
}

将主路线注释掉编译运行,再解除注释编译运行,即可看到对比效果。

每次使用go关键字都会产生一个新的goroutine。表面上看,goroutine似乎在同时运行,但由于计算机处理单元有限,其实技术上来说,这些goroutine不是真的在同时运行(计算机处理器会使用"分时"技术,在多个goroutine上轮流花费一些时间;在使用goroutine时,各个goroutine的执行顺序无法确定)。

向goroutine传递参数就跟向函数传递参数一样,参数都是按值传递的

代码的问题:无法知道Goroutine要执行多长时间,也就不知道main函数到底需要等待多久。下一节通道可以解决此问题。

相关推荐
952361 小时前
MyBatis
后端·spring·mybatis
FQNmxDG4S3 小时前
Java多线程编程:Thread与Runnable的并发控制
java·开发语言
前端老石人3 小时前
HTML 字符引用完全指南
开发语言·前端·html
matlab_xiaowang3 小时前
Redux 入门:JavaScript 可预测状态管理库
开发语言·javascript·其他·ecmascript
虹科网络安全4 小时前
艾体宝干货|数据复制详解:类型、原理与适用场景
java·开发语言·数据库
axng pmje4 小时前
Java语法进阶
java·开发语言·jvm
uzong4 小时前
9 种 RAG 架构,每位 AI 开发者必学:完整实战指南
后端
老前端的功夫4 小时前
【Java从入门到入土】28:Stream API:告别for循环的新时代
java·开发语言·python
qq_435287924 小时前
第9章 夸父逐日与后羿射日:死循环与进程终止?十个太阳同时值班的并行冲突
java·开发语言·git·死循环·进程终止·并行冲突·夸父逐日
小江的记录本4 小时前
【Kafka核心】架构模型:Producer、Broker、Consumer、Consumer Group、Topic、Partition、Replica
java·数据库·分布式·后端·搜索引擎·架构·kafka