相比synchronized读写锁究竟带来什么

多线程


先看一段代码

public class TestSync2 implements Runnable {

 int  b=100;

    public int  getB() {
        return b;
    }

    @Override

    public void run() {

        try {

            m1();

        } catch (InterruptedException e) {

            // TODO Auto-generated catch block

            e.printStackTrace();

        }

    }

    synchronized void m1() throws InterruptedException {
        System.out.println("m1");
        b=1000;
        Thread.sleep(500);
        b=666;
        System.out.println("b="+b);

    }

    synchronized void m2() throws InterruptedException {
        System.out.println("m2");

        Thread.sleep(250);

        b=2000;

    }

    public static void main(String[] args) throws InterruptedException {

        TestSync2 tt=new TestSync2();

        Thread t = new Thread(tt);

        t.start();

        tt.m2();
//        Thread.sleep(2000);
        System.out.println("main thread b="+tt.getB());

    }

运行结果为
在这里插入图片描述
或者
在这里插入图片描述
请注意变量i没加volatile,读出来的都是最新的。这是因为当一个类中有方法synchronized修饰的时候,里面涉及的变量无需加

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值