实战多线程之synchronized

本文通过一个实战案例,展示了如何在多线程环境下使用`synchronized`关键字来保证线程安全。线程一负责数值增加,线程二负责数值减少,通过`synchronized`确保了操作的原子性和可见性,避免并发问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

案例说明:

两个线程同时操作一个数,一个线程操作加,另一个线程操作减:

package com.My.Schedule_test.demo.ConPro;

public class zongjie{

    static int r = 5;//被操作数
    static final int Max = 5;//操作数的最大值
    static Boolean order = false;//状态值:false代表递减,true代表递增

    private String name;
    public zongjie(String name){
//        super(name);
        this.name = name;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }


    public void incre(){
        synchronized (this){
            while(r >= Max || !order){//当操作数到达最大值或者还是递减状态的情况下
                order = false;
                System.out.println("太大了,需要递减!");
                this.notifyAll();//唤醒其余线程

                try{
                    this.wait();//进入等待
                }catch (InterruptedException e){
                    e.printStackTrace();
                }
            }

//            System.out.println("开始递增");
            r += 1;


            System.out.println(Thread.currentThread().getName() + "开始递增-->r=" + r);

        }
    }

    
 public void reduce(){
        synchronized (this){
            while(r <= 0 || order){//当操作数满足最小值或处于递增状态时
                order = true;
                System.out.println("太小了, 需要递增!");
                this.notifyAll();
                try {
                    this.wait();
                }catch (InterruptedException e){
                    e.printStackTrace();
                }
            }
            r -= 1;

            System.out.println(Thread.currentThread().getName() + "开始递减-->r=" + r);
        }
    }

上述就是操作对象的代码,其中的代码说明已经通过注释进行讲解。

接下来就是实现线程代码继承Thread。一个自增一个自减。

package com.My.Schedule_test.demo.ConPro;

public class Operationadd extends Thread {

    zongjie z;

    private String name;
    public Operationadd(String name, zongjie z){
        this.z = z;
        this.name = name;
    }



    @Override
    public void run(){

        while(true){
            z.incre();
            try{
                sleep(1000);
            }catch (InterruptedException e){
                e.printStackTrace();
            }
        }

    }

}
package com.My.Schedule_test.demo.ConPro;

public class OperationReduce extends Thread {

    zongjie z;
    private String name;
    public OperationReduce(String name, zongjie z){
        this.name = name;
        this.z = z;
    }



    @Override
    public void run(){
        while(true){
            z.reduce();
            try{
                sleep(1000);
            }catch (InterruptedException e){
                e.printStackTrace();
            }
        }
    }

}

这样就实现了,自增自减,结果表现为:

Thread-1开始递减-->r=3
Thread-1开始递减-->r=2
Thread-1开始递减-->r=1
Thread-1开始递减-->r=0
太小了, 需要递增!
Thread-0开始递增-->r=1
Thread-0开始递增-->r=2
Thread-0开始递增-->r=3
Thread-0开始递增-->r=4
Thread-0开始递增-->r=5
太大了,需要递减!
Thread-1开始递减-->r=4
Thread-1开始递减-->r=3
Thread-1开始递减-->r=2
Thread-1开始递减-->r=1
Thread-1开始递减-->r=0
太小了, 需要递增!
Thread-0开始递增-->r=1
Thread-0开始递增-->r=2
Thread-0开始递增-->r=3
Thread-0开始递增-->r=4
Thread-0开始递增-->r=5
太大了,需要递减!


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值