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:如果你不是非常严格地(从系统级杜绝不该被执行的线程被调用)要求线程切换的话,这个逻辑应该可以工作。自己没有试,希望你明白我的思想,如有错误,自己再修改一下。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)