在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">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号