在linux系统中,我们可以巧妙地利用信号量来控制两个线程之间的执行顺序。通过设置信号量的初始值,并通过命令行参数指定哪个线程先输出数字,我们可以实现第0号线程或第1号线程优先执行的效果。程序命名为sem-syn-p.c。
我们定义两个信号量,分别设置为1和0。想要哪个线程先执行,就将该线程所需的信号量初始值设为1。这样,第一个线程就可以进入执行区块。而后执行的线程所需的信号量初始值设为0,它会在P(等待)操作处阻塞,直到第一个线程通过V(唤醒)操作将其信号量值设为1。
这种方法实现了严格的轮转执行顺序:如果我们命令行输入0,表示0号线程先执行,那么我们将0号线程的信号量设置为1,1号线程的信号量设置为0。反之,如果输入1,表示1号线程先执行,则将1号线程的信号量设置为1,0号线程的信号量设置为0。


以下是实现上述功能的代码示例:
#include <semaphore.h>
#include <stdio.h>
#include <pthread.h>
#include <stdlib.h>
#include <unistd.h>
<p>sem_t s1, s2;</p><p>void<em> runner(void</em> p) {
long tnum = (long)p;
for (int i = 1; i <= 5; i++) {
if (tnum == 0) {
sem_wait(&s1);
printf("Thread %ld: %d\n", tnum, i);
sem_post(&s2);
} else {
sem_wait(&s2);
printf("Thread %ld: %d\n", tnum, i);
sem_post(&s1);
}
}
return NULL;
}</p><p>int main(int argc, char* argv[]) {
pthread_t tid1, tid2;
long t1 = 0, t2 = 1;</p><pre class="brush:php;toolbar:false;"><code>if (argc != 2) {
fprintf(stderr, "Usage: %s <0|1>\n", argv[0]);
exit(1);
}
int first = atoi(argv[1]);
if (first == 0) {
sem_init(&s1, 0, 1);
sem_init(&s2, 0, 0);
} else if (first == 1) {
sem_init(&s1, 0, 0);
sem_init(&s2, 0, 1);
} else {
fprintf(stderr, "Invalid argument. Use 0 or 1.\n");
exit(1);
}
pthread_create(&tid1, NULL, runner, (void*)t1);
pthread_create(&tid2, NULL, runner, (void*)t2);
pthread_join(tid1, NULL);
pthread_join(tid2, NULL);
sem_destroy(&s1);
sem_destroy(&s2);
return 0;}
通过上述代码,我们实现了根据命令行参数控制两个线程执行顺序的功能。
以上就是【Linux】巧妙运用< 信号量 >控制 <两个线程>之间<谁先执行>的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号