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函数到底需要等待多久。下一节通道可以解决此问题。

相关推荐
子玖1 小时前
go实现通过ip解析城市
后端·go
Java不加班1 小时前
Java 后端定时任务实现方案与工程化指南
后端
心在飞扬2 小时前
RAG 进阶检索学习笔记
后端
Moment2 小时前
想要长期陪伴你的助理?先从部署一个 OpenClaw 开始 😍😍😍
前端·后端·github
Das1_2 小时前
【Golang 数据结构】Slice 底层机制
后端·go
得物技术2 小时前
深入剖析Spark UI界面:参数与界面详解|得物技术
大数据·后端·spark
古时的风筝2 小时前
花10 分钟时间,把终端改造成“生产力武器”:Ghostty + Yazi + Lazygit 配置全流程
前端·后端·程序员
Cache技术分享2 小时前
340. Java Stream API - 理解并行流的额外开销
前端·后端
初次攀爬者2 小时前
RocketMQ 消息可靠性保障与堆积处理
后端·消息队列·rocketmq