【Linux】一个简单while循环实现【严格轮转】,从而理解什么是【多线程的忙等待】
前言
大家好吖,欢迎来到 YY 滴Linux系列 ,热烈欢迎! 本章主要内容面向接触过C++的老铁
主要内容含:
欢迎订阅 YY滴C++专栏!更多干货持续更新!以下是传送门!
- YY的《C++》专栏
- YY的《C++11》专栏
- YY的《Linux》专栏
- YY的《数据结构》专栏
- YY的《C语言基础》专栏
- YY的《初学者易错点》专栏
- YY的《小小知识点》专栏
- YY的《单片机期末速过》专栏
- YY的《C++期末速过》专栏
- YY的《单片机》专栏
- YY的《STM32》专栏
- YY的《数据库》专栏
- YY的《数据库原理》专栏
目录
- 一.忙等待介绍
- 二.忙等待代码题解析
一.忙等待介绍
- 忙等待(Busy-waiting)是一种同步机制,其中一个进程或线程 重复检查某个条件是否满足 以便继续执行,而不是进入休眠或阻塞状态。
- 于是我们便可以用while循环,让 不符合条件/顺序的线程 符合while循环条件 进入里面进入忙等待状态,达到 重复检查 效果;而不是不符合条件运行或者直接啥也不干结束;
二.忙等待代码题解析
题干:
- 创建两个线程,分别是线程1和线程0,每隔1s输出1到10的数字;
- 要求线程1先输出,线程0后输出;
- 不使用条件变量,互斥量
代码:
#include <stdio.h>
#include <stdlib.h>
#include <pthread.h>
#include <unistd.h>
int turn = 0; // 全局标志变量,用于控制线程1和线程0的执行顺序
void* thread_func(void* arg) {
long tnum=(long)param;
while(tnum!=turn);//线程号不为1就关在这里,重复检查,即忙等待
for (int i = 1; i <= 10; ++i)
{
printf("Thread 0: %d\n", i);
sleep(1);
}
turn=1;//实现严格轮转,把turn改成下一个将要进行的进程号
}
int main() {
pthread_t thread0, thread1;
long tnum1=0;
long tnum2=1;
// 创建线程1和线程0
pthread_create(&thread1, NULL, thread_func, tnum1);
pthread_create(&thread0, NULL, thread_func, tnum2);
// 等待线程1和线程0完成
pthread_join(thread1, NULL);
pthread_join(thread0, NULL);
return 0;
}