浅谈协程并发竞争资源问题

简介: 浅谈协程并发竞争资源问题

浅谈协程并发竞争资源问题

我们在实际操作过程中,往往会遇到拥有多条协程并发的情况,那么当多条协程并发时,协程之间是如何竞争有限的资源的呢?本文将介绍有关内容。

我们先看一看本文实例代码的主函数,两条子协程,主协程3秒后结束。

func main() {
    go fun1()
    go fun2()

    time.Sleep(3 * time.Second)
}

再看看看两条子协程分别是干些什么吧!

func fun1(){
    //遍历字符串的每一个字符
    for _,c:=range "就像老鼠爱大米"{
        //如果这里使用Println的话,输出的会是字符在字符集中的编号。
        //这里f是format也就是格式的意思。
        fmt.Printf("%c\n",c)
        //runtime.Goexit()
        //每隔一纳秒打印一个字。
        time.Sleep(time.Nanosecond)
    }

}

func fun2(){
    for _,c := range"ReganYue"{
        fmt.Printf("%c\n",c)
        //runtime.Goexit()
        time.Sleep(time.Nanosecond)

    }
}

fun1函数,是遍历输出"就像老鼠爱大米",值得注意的是,这里使用for...range循环遍历字符串的话,不能使用fmt.Println,因为如果这里使用Println的话,输出的会是字符在字符集中的编号。

fmt.Printf 这里f是format也就是格式化的意思。

看看运行结果

R
就
像
e
g
老
鼠
a
n
爱
Y
大
米
u
e

发现两条协程运行的结果均匀分布。这就说明两条协程公平竞争资源,两条协程之间实力旗鼓相当。

可如果激活fun1内的runtime.Goexit()

那么输出结果就是:

就
R
e
g
a
n
Y
u
e

如果激活fun2内的runtime.Goexit()

那么输出结果就是:

就
R
像
老
鼠
爱
大
米

因为Goexit 杀掉它的 goroutine,其他 goroutine 也不会受到影响。所以当fun1的所在的子协程被杀死时,不会影响fun2所在的子协程的正常运行。

如果本段代码中两个runtime.Goexit()都激活,那么两条协程都只会输出一个字符。

就
R

因为两条协程在输出完一个字符后就被杀死了。

如果两个及以上个协程在没有同步的情形下去访问共享的资源,并且尝试同一时间读和写共享的资源。就会出现资源竞争问题。出现的这个问题能够让程序变得稍微复杂,本文就暂时不讨论这些复杂情况,想知道的可以关注博主,博主后期会介绍。

我们也可以使用 go build-race 参数,使用它可以了解是否存在资源竞争问题,关于 go build-race 参数的使用,本篇博文暂不介绍,后期博主会尽量详细介绍。

目录
相关文章
|
3月前
|
安全 Go
Golang语言goroutine协程并发安全及锁机制
这篇文章是关于Go语言中多协程操作同一数据问题、互斥锁Mutex和读写互斥锁RWMutex的详细介绍及使用案例,涵盖了如何使用这些同步原语来解决并发访问共享资源时的数据安全问题。
100 4
|
2月前
|
安全 Go 调度
探索Go语言的并发模式:协程与通道的协同作用
Go语言以其并发能力闻名于世,而协程(goroutine)和通道(channel)是实现并发的两大利器。本文将深入了解Go语言中协程的轻量级特性,探讨如何利用通道进行协程间的安全通信,并通过实际案例演示如何将这两者结合起来,构建高效且可靠的并发系统。
|
3月前
|
数据采集 消息中间件 并行计算
进程、线程与协程:并发执行的三种重要概念与应用
进程、线程与协程:并发执行的三种重要概念与应用
66 0
|
4月前
|
监控 Devops 测试技术
|
5月前
|
消息中间件 算法 Java
(十四)深入并发之线程、进程、纤程、协程、管程与死锁、活锁、锁饥饿详解
本文深入探讨了并发编程的关键概念和技术挑战。首先介绍了进程、线程、纤程、协程、管程等概念,强调了这些概念是如何随多核时代的到来而演变的,以满足高性能计算的需求。随后,文章详细解释了死锁、活锁与锁饥饿等问题,通过生动的例子帮助理解这些现象,并提供了预防和解决这些问题的方法。最后,通过一个具体的死锁示例代码展示了如何在实践中遇到并发问题,并提供了几种常用的工具和技术来诊断和解决这些问题。本文旨在为并发编程的实践者提供一个全面的理解框架,帮助他们在开发过程中更好地处理并发问题。
|
6月前
|
安全 Android开发 Kotlin
Android面试题之Kotlin协程并发问题和互斥锁
Kotlin的协程提供轻量级并发解决方案,如`kotlinx.coroutines`库。`Mutex`用于同步,确保单个协程访问共享资源。示例展示了`withLock()`、`lock()`、`unlock()`和`tryLock()`的用法,这些方法帮助在协程中实现线程安全,防止数据竞争。
87 1
|
5月前
|
Java Go 调度
Java演进问题之协程和线程在资源占用和切换速度上不同如何解决
Java演进问题之协程和线程在资源占用和切换速度上不同如何解决
|
6月前
|
监控 程序员 调度
协程实现单线程并发(入门)
协程实现单线程并发(入门)
69 1
|
Linux Go 调度
Go 协程为什么比进程和线程占用的系统资源低?
Go 协程为什么比进程和线程占用的系统资源低?
76 0
|
7月前
|
存储 Python
python使用gevent库来创建协程,并通过协程实现并发执行不同的任务
```markdown 这段Python代码利用`gevent`库实现并发执行协程。定义了两个打印函数`f1`和`f2`,分别输出"csdn"和"yyds"。代码首先创建列表`t_l`,并启动5个`f1`协程,将其加入列表并等待所有协程完成。随后,同样方式启动5个`f2`协程,存入`t1_l`列表并等待执行完毕。整体展示了`gevent`的协程并发操作。 ```
59 1