C++使用多线程交替打印1~10

C++使用多线程交替打印1~10

使用多线程交替打印1-10,线程1打印奇数,线程2打印偶数,有两种方式实现,一种是使用信号量(即互斥锁),另一种是不使用互斥量,人为控制number的读写。

以下为个人想法,可能有错误:
  这是一个面试很常见的题目,要求交替打印,使用互斥量的原理很简单,就是确保一个线程在对number进行操作的时候给number上锁,使得其他线程不能访问number,必须等该线程释放number的锁后,其他线程才能访问number,一句话,使用锁就是确保number操作的原子性。
  而如果不使用锁呢,如何手动控制number的原子性,我的想法是,在进入先判断number的值,然后将number的值复制到temp_number,对temp_number进行操作,加1和输出,最后操作都结束后,在将temp_number的值赋值给number,避免多次读取number的值。其实分为三步,读取备份–> 修改备份 --> 写回number,结束。
  下面是实现的代码,主推方法1吧,毕竟这才是正规标准的写法。而方法2没有使用信号量,算是自己胡思乱想的尝试,而且面试也不推荐写方法2的代码,不使用信号量估计会被面试官锤!!!

方法1. 信号量(锁)实现

#include <iostream>
#include <thread>
#include <mutex>

using namespace std;

int number;
mutex mutex_number;

const int MAXNUM = 10;

// 打印奇数
void add_1() {
   
   
    while (1) {
   
   
        mutex_number.lock();
        if (number >= MAXNUM) {
   
   
            mutex_number.unlock();
            break;
        }
        if (number % 2 == 0) {
   
   
            number++;
            cou
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值