变量的并发访问

本文通过一个具体的Java示例探讨了线程安全问题,特别是针对方法内局部变量和实例变量的区别,展示了即使没有使用synchronized等同步手段,方法内的私有变量也能保持线程安全。

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

synchronized的同步方法

方法内的变量为线程安全的

"非线程安全" 问题存在于“实例变量”中,如果是方法内部的私有变量,则不存在“非线程安全”问题,也就是线程安全。

public class HasSelfPrivateNum  {


    public void addI(String name) {
        try {
            int num = 0;
            if ("a".equals(name)) {
                num=100;
                System.out.println("a set over!");
                Thread.sleep(2000);
            } else {
                num = 200;
                System.out.println("b set over!");
            }
            System.out.println(name +" num="+num);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}
线程A
public class ThreadA extends  Thread {
    private HasSelfPrivateNum hasSelfPrivateNum;

    public ThreadA(HasSelfPrivateNum hasSelfPrivateNum) {
        this.hasSelfPrivateNum = hasSelfPrivateNum;
    }

    @Override
    public void run() {
        hasSelfPrivateNum.addI("a");
    }
}

线程B
public class ThreadB  extends  Thread{
    private HasSelfPrivateNum hasSelfPrivateNum;

    public ThreadB(HasSelfPrivateNum hasSelfPrivateNum) {
        this.hasSelfPrivateNum = hasSelfPrivateNum;
    }

    @Override
    public void run() {
        hasSelfPrivateNum.addI("b");
    }
}

运行
public class Run {
    public static void main(String[] args) throws Exception{
        HasSelfPrivateNum hasSelfPrivateNum=new HasSelfPrivateNum();
        ThreadA  threadA=new ThreadA(hasSelfPrivateNum);
        ThreadB threadB=new ThreadB(hasSelfPrivateNum);
        threadA.start();
        threadB.start();
    }
}
运行结果:
a set over!
b set over!
b num=200
a num=100


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值