java并发编程是程序员基本技能。
我是李福春,我在准备面试,今天的题目是:
synchronized和ReentrantLock的区别?
这两货都是java提供的同步机制,提供了互斥语义和可见性,当一个线程获得资源之后,其它竞争资源的线程必须等待或者堵塞。
区别如下:
线程安全说的是多线程场景下,共享可修改状的数据的正确性。
从语义来看,保证线程安全的方法有2:
1, 封装起来,数据不共享,私有化。
2, 数据不可修改,自然不存在线程不安全。final,immutable;
线程安全的3个特性:
隔离性: 相关操作不会被其它线程干扰
顺序性: 线程内的串行语义,避免指令重排;
可见性: 线程的本地变量修改应该反馈到主内存上,使用volatile关键字。
先来看一个线程不安全的例子:
package org.example.mianshi.concurrent; /** * 线程不安全例子,共享数据sharedState * @author lifuchun */ public class ThreadSafeSample { public int sharedState; public void nonSafeAction() { while (sharedState < 100000) { int former = sharedState++; int latter = sharedState; if (former != latter - 1) { System.out.printf("Observed data race, former is " + former + ", " + "latter is " + latter); } } } public static void main(String[] args) throws InterruptedException { final ThreadSafeSample sample = new ThreadSafeSample(); Thread threadA = new Thread() { @Override public void run() { sample.nonSafeAction(); } }; Thread threadB = new Thread() { @Override public void run() { sample.nonSafeAction(); } }; threadA.start(); threadB.start(); threadA.join(); threadB.join(); } }
共享了数据,然后只有两个线程修改,就表现出数据的不一致性。
然后可以改造一下,分别使用sychronized ,ReetrantLock改造,保证线程安全。
本篇对比了sychronized和ReetrantLock的区别;
然后说了线程安全的概念和保证线程手段。
原创不易,转载请注明出处,让我们互通有无,共同进步,欢迎沟通交流。