Java中synchronization的三种应用方式

本文详细介绍了Java中synchronization的三种应用方式:1) 修饰实例方法,通过实例加锁防止并发问题;2) 修饰静态方法,通过类对象加锁确保线程安全;3) 修饰代码块,指定对象加锁,更加灵活。通过对共享资源的锁定,避免了多线程同时访问导致的数据不一致问题。

1 :synchronization的三种修饰情况(为什么使用synchronization:避免多线程同时访问共享资源时造成的并发问题)
1.1:修饰实例方法,作用于当前的实例加锁,进入同步代码前要获得当前实例的锁
如下代码未使用synchronization进行修饰时
在这里插入图片描述
结果为什么出现 192924 而不是期望值 200000:当线程 t1,t2,同时操作 i 时,i为共享的资源;
线程执行分为2 步,第一步为 获取 i 的值,第二步为 i++
可能出现当 线程 t1 获取 i 时还未执行完 i++这个过程中,线程 t2 也获得了 i ,接着也继续执行;
例如:t1 获取 i = 100 时,未执行 i++,t2 也获取 i=100,当t1,t2都执行完此次 i ++ 时,i=101并不是
102,所有循环完的结果 < 200000;

方法加上 synchronization进行修饰,如下:

在这里插入图片描述
执行结果始终都是 200000, 在synchronization修饰实例方法;例如 当线程 t1 调用add()方法时,活产生实例对象 s1 的对象锁,只有当线程
t1 执行完成后,才会释放该对象锁,之后线程 t2 获取该对象锁,不会出现同一时刻,线程 t1,t2 同时获取共享资源执行 i++的情况,所有
i 的结果始终都是 200000;
1.2:修饰静态方法,作用于当前类对象的实例,进入同步代码前要获取当前类对象的锁
两个新实例操作同一共享资源且为修饰非静态方法
在这里插入图片描述
并未出现期望值20000,因为 s1,s2 为不同的实例,在执行同步代码前获取的不是同一个对象锁,对应的分别是 s1, s2 各自的对象锁,
共享资源 i 并没有被对象锁锁住;
静态( static +synchronized ) 修饰方法,那么该同步代码只有一个锁,就是当前类的对象锁,线程 t1,t2 执行代码前获得的对象锁都是当前类
的对象锁,必须是一个执行完释放该锁,另一个才能重新获取该对象锁进行执行
在这里插入图片描述
1.3 :synchronized修饰代码块
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值