主体思路:通过对线程1加锁,使用条件变量,如果线程1执行完一次,就重置标志位,让线程1等待,通知线程2,如果线程2等待成功,就执行线程2,然后再重置标志位,执行线程1,交替执行即可。
具体代码如下所示:
void f2()
{
int N=100;
condition_variable cv;
int flag=true;
thread t1([&](){
for(int i=1;i<N;)
{
unique_lock<mutex> lock(mtx); //加锁
cv.wait(lock,[&flag]()->bool {return flag;});
//如果返回false,wait什么也不做,一直等待
//并且出作用域,自动析构,不用解锁
cout<<"线程1"<<" "<<i<<endl;
i+=2;
flag=false; //线程2迟迟未创建,此时flag为false,一直wait,
cv.notify_one();//线程2创建以后,通知线程2执行
}
});
thread t2([&](){
for(int i=2;i<N;)
{
unique_lock<mutex> lock(mtx);
cv.wait(lock,[&flag]()->bool {return !flag;});//此时flag为false,!flag为true,可执行
cout<<"线程2"<<" "<<i<<endl;
i+=2;
flag=true;//再去通知一号线程
cv.notify_one();
}
});
t1.join();
t2.join();
}
int main()
{
f2();
return 0;
}