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修饰代码块

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

被折叠的 条评论
为什么被折叠?



