linux线程是如何进行切换的?

linux线程是如何进行切换的?,第1张

基于你的描述,我想可以用互斥信号量来做。

1、初始化2个信号量pmutex1(有资源), pmutex2(无资源),初始化gnum=0

2、启动两个线程

2.1 线程1

lock_the_mutex_signal(pmutex1) // 上锁自身线程,首次可执行

while (gnum <5) {

do_sth() // 做你的业务逻辑

gnum++ // 增加执行次数

} // end while()

unlock_the_mutex_signal(pmutex2)// 解锁另一线程

2.2 线程2

lock_the_mutex_signal(pmutex2) // 上锁自己,首次执行将阻塞,并交出CPU

while (gnum >5) {

do_sth()// ...

gnum--// ...

} // end while()

unlock_the_mutex_signal(pmutex1)// release the lock

PS:如果你不是非常严格地(从系统级杜绝不该被执行的线程被调用)要求线程切换的话,这个逻辑应该可以工作。自己没有试,希望你明白我的思想,如有错误,自己再修改一下。

Linuxsleep(0)是Linux内核中的一个系统调用,它可以让线程在指定的时间内进入睡眠状态,从而实现线程切换。它可以用来实现定时器功能,也可以用来实现线程同步。它的原理是,当线程调用linuxsleep(0)时,它会把自己放入睡眠队列,并且把当前的CPU时间片设置为0,这样就可以实现线程切换。当睡眠时间到达时,线程会被唤醒,然后继续执行。因此,linuxsleep(0)可以用来实现线程切换,从而提高系统的性能。

你这个问题很有意思。第一次执行的时候,可以看出,能执行0~6共7次;第二次的时候,从6开始,到5,只有2次了,并且以后都是只有2次。

基于你的描述,我想可以用互斥信号量来做。

1、初始化2个信号量pmutex1(有资源), pmutex2(无资源),初始化gnum=0

2、启动两个线程

2.1 线程1

lock_the_mutex_signal(pmutex1) // 上锁自身线程,首次可执行

while (gnum <5) {

do_sth() // 做你的业务逻辑

gnum++ // 增加执行次数

} // end while()

unlock_the_mutex_signal(pmutex2)// 解锁另一线程

2.2 线程2

lock_the_mutex_signal(pmutex2) // 上锁自己,首次执行将阻塞,并交出CPU

while (gnum >5) {

do_sth()// ...

gnum--// ...

} // end while()

unlock_the_mutex_signal(pmutex1)// release the lock

PS:如果你不是非常严格地(从系统级杜绝不该被执行的线程被调用)要求线程切换的话,这个逻辑应该可以工作。自己没有试,希望你明白我的思想,如有错误,自己再修改一下。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/8615028.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-18
下一篇 2023-04-18

发表评论

登录后才能评论

评论列表(0条)

保存