java多线程实现奇偶数输出

两种实现方式1:普通synchronized版实现、 2:使用Semaphore版实现
一:普通synchronized版实现

在这里插入代码片public class Ceshi999 {
    static int result = 0;

    public static void main(String[] args){
        Thread thread = new Thread(new Jiou(0));
        thread.start();
        Thread thread1 = new Thread(new Jiou(1));
        thread1.start();
    }
    static class Jiou implements Runnable{
        private int i;
        public Jiou(int i){
            this.i = i;
        }
        @Override
        public void run() {
            while (result<100){
                synchronized (Jiou.class){
                    System.out.println("thread"+i+":"+result++);
                    Jiou.class.notify();
                    try {
                        Jiou.class.wait();
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }
            }
        }
    }
}

二:使用Semaphore版实现

public class Ceshi888 {
    static  int result = 0;
    public static void main(String[] args) throws InterruptedException {
        int N = 3;
        Thread threads[] = new Thread[N];//声明N个数据
        Semaphore semaphore[] = new Semaphore[N];//声明N个信息号量
        for(int i=0;i<N;i++){
            semaphore[i] = new Semaphore(1);
            if(i!=N-1){//最后一个不获取信号量许可
                semaphore[i].acquire();//获取一个信号量许可
            }
        }
        for(int i=0;i<N;i++){
            Semaphore lastSemaphore = i==0 ? semaphore[N-1]:semaphore[i-1];//0:2  1:0 2:1   0的最后一个信号量是2,1的最后一个信号量是0,2的后一个信号量是1
            Semaphore currentSemphore = semaphore[i];//当前信号量
            int index = i;
            threads[i] = new Thread(new Runnable() {
                @Override
                public void run() {
                    while(true){
                        try {
                            lastSemaphore.acquire();//每次只会有一个信号量获得许可,顺序为2,0,1
                            System.out.println("thread"+index+":"+( result++));
                            if(result>100){
                                System.exit(0);
                            }
                        }catch (Exception e){
                            e.printStackTrace();
                        }finally {
                            currentSemphore.release();
                        }
                    }
                }
            });
            threads[i].start();
        }
    }
}
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值