Java 线程同步

1.Synchronized

Java提供关键字synchronized来防止资源冲突。当任务要执行被synchronized关键字保护的代码片段时,它将检查锁是否可用,然后获取锁,执行代码,释放锁。

如果一个任务处于一个对标记为synchronized的方法的调用中,那么在这个线程从该方法返回之前,其他所有要调用类中标记为synchronized方法的线程都会被阻塞。

2.Lock

Lock对象必须被显式的创建锁定和释放

Lock lock = new ReentrantLock();

lock.unlock();

3.volatile

a:volatile关键字为域变量的访问提供了一种免锁机制,

b:使用volatile修饰域相当于告诉虚拟机该域可能会被其他线程更新,

c:因此每次使用该域就要重新计算,而不是使用寄存器中的值

d:volatile不会提供任何原子操作,它也不能用来修饰final类型的变量

5:使用局部变量实现线程同步

如果使用ThreadLocal管理变量,则每一个使用该变量的线程都获得该变量的副本,

副本之间相互独立,这样每一个线程都可以随意修改自己的变量副本,而不会对其他线程产生影响。

ThreadLocal() : 创建一个线程本地变量

get() : 返回此线程局部变量的当前线程副本中的值

initialValue() : 返回此线程局部变量的当前线程的"初始值"

set(T value) : 将此线程局部变量的当前线程副本中的值设置为value


6.使用原子变量实现线程同步

原子操作就是指将读取变量值、修改变量值、保存变量值看成一个整体来操作

即-这几种行为要么同时完成,要么都不完成。

在java的util.concurrent.atomic包中提供了创建了原子类型变量的工具类

使用该类可以简化线程同步。

其中AtomicInteger表可以用原子方式更新int的值,可用在应用程序中(如以原子方式增加的计数器),

但不能用于替换Integer;可扩展Number,允许那些处理机遇数字类的工具和实用工具进行统一访问。

AtomicInteger类常用方法:

AtomicInteger(int initialValue) : 创建具有给定初始值的新的AtomicInteger

addAddGet(int dalta) : 以原子方式将给定值与当前值相加

get() : 获取当前值

你可能感兴趣的:(Java 线程同步)