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:如果你不是非常严格地(从系统级杜绝不该被执行的线程被调用)要求线程切换的话,这个逻辑应该可以工作。自己没有试,希望你明白我的思想,如有错误,自己再修改一下。
Linux内核切换线程时间在微秒级别,几十微秒。
1. 查看需要更新的内核命令:
apt-cache search linux#该命令将会显示所有可以获取的内核
2. 安装内核,假设要安装的内核为2.6.39-0,则使用下面的命令
sudo apt-get install linux-headers-2.6.39-0-generic linux-image-2.6.39-0-generic#安装后,reboot即可,重启后,既是以新内核启动。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)