java-使用生产者消费者模式交替输出奇偶数

使用生产者和消费者模式,交替输出奇数偶数
t1-1
t2-2
t1-3
t2-4

要求两个线程共享一个数字,交替输出

public class ThreadTest {
    public static void main(String[] args) {
        Num num=new Num();
        Thread t1=new Thread(new MyThreadOne(num));
        Thread t2=new Thread(new MyThreadTwo(num));
        t1.setName("奇数");
        t2.setName("偶数");
        t1.start();
        t2.start();
    }
}

//创建数字类
class Num{
    int i=1;//设定初始值为1
}

//输出奇数的线程
class MyThreadOne implements Runnable{
    private Num num;

    public MyThreadOne(Num number) {
        this.num = number;
    }

    @Override
    public void run() {
        //一直输出奇数
        while (true){
            //上锁
            synchronized (num){
                if(num.i%2==0){//若是偶数就wait
                    try {
                        num.wait();
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }
                //若不是偶数
                System.out.println(Thread.currentThread().getName()+(num.i++));
                //每隔一秒执行一次
                try {
                    Thread.sleep(1000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                //唤醒
                num.notify();
            }
        }
    }
}

//输出偶数的线程
class MyThreadTwo implements Runnable{
    private Num num;

    public MyThreadTwo(Num number) {
        this.num = number;
    }
    @Override
    public void run() {
        while (true){
            synchronized (num){
                if(num.i%2==1){//若是奇数就wait
                    try {
                        num.wait();
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }
                //若不是奇数
                System.out.println(Thread.currentThread().getName()+(num.i++));
                //每隔一秒执行一次
                try {
                    Thread.sleep(1000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                //唤醒
                num.notify();
            }
        }
    }
}
  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
生产者消费者模型是一个经典的并发编程问题,在多线程环境下需要进行进程同步和互斥。其中,生产者负责向缓冲区中放置据,而消费者则负责从缓冲区中取出据。 在实验中,我们可以通过使用信号量来实现进程同步和互斥。具体地说,我们可以使用两个信号量:一个用于表示缓冲区是否为空,另一个用于表示缓冲区是否已满。 当生产者向缓冲区中放入据时,它会获取“缓冲区是否已满”的信号量。如果缓冲区已满,则生产者需要等待,直到有空间可用。一旦缓冲区有空间,生产者就会向缓冲区中放入据,并释放“缓冲区是否为空”的信号量。 当消费者从缓冲区中取出据时,它会获取“缓冲区是否为空”的信号量。如果缓冲区为空,则消费者需要等待,直到有据可用。一旦缓冲区有据,消费者就会从缓冲区中取出据,并释放“缓冲区是否已满”的信号量。 通过这种方式,我们可以确保生产者和消费者能够正确地交替执行,并且不会出现据竞争和死锁等问题。 下面是一个生产者消费者模型的实验结果截图: ![生产者消费者模型实验结果截图](https://img-blog.csdnimg.cn/20211210145604663.png) 从截图中可以看出,在多线程环境下,生产者和消费者能够正确地交替执行,并且不会出现据竞争和死锁等问题。同时,缓冲区的大小也可以根据需要进行调整,以满足不同的需求。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值