3.2. 解决代码
package cn.enjoy.syn;
import java.text.SimpleDateFormat;
import java.util.Date;
public class OrderNumGenerator {
//全局订单id
public static int count = 0;
public static Object lock = new Object();
public String getNumber() {
synchronized(lock){
SimpleDateFormat simpt = new SimpleDateFormat(“yyyy-MM-dd-HH-mm-ss”);
return simpt.format(new Date()) + “-” + ++count/+“_”+Thread.currentThread().getId()/;
}
}
}
4. Lock解决方案
4.1. 解决原理
4.2. 解决代码
package cn.enjoy.lock;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.concurrent.locks.ReentrantLock;
public class OrderNumGenerator {
//全局订单id
public static int count = 0;
private java.util.concurrent.locks.Lock lock = new ReentrantLock();
//以lock的方式解决
public String getNumber() {
try {
lock.lock();
SimpleDateFormat simpt = new SimpleDateFormat(“yyyy-MM-dd-HH-mm-ss”);
String s = simpt.format(new Date()) + “-” + ++count;
return s;
}finally {
lock.unlock();
}
}
}
5. 谈一个面试题
Synchronized与Lock 都能解决并发安全问题,但他们有哪些区别呢?**
Lock接口比同步方法和同步块提供了更具扩展性的锁操作。
他们允许更灵活的结构,可以具有完全不同的性质,并且可以支持多个相关类的条件对象。
它的优势有:可以使锁更公平,可以使线程在等待锁的时候响应中断,可以让线程尝试获取锁,并在无法获取锁的时候立即返回或者等待一段时间,可以在不同的范围,以不同的顺序获取和释放锁。
整体上来说Lock是synchronized的扩展版,Lock提供了无条件的、可轮询的(tryLock方法)、定时的(tryLock带参方法)、可中断的(lockInterruptibly)、可多条件队列的(newCondition方法)锁操作。另外Lock的实现类基本都支持非公平锁(默认)和公平锁,synchronized只支持非公平锁,当然,在大部分情况下,非公平锁是高效的选择。
通过这些描述,总结出来,区别如下
-
Lock提供更灵活的功能
-
Lock可以实现公平锁的功能,如下图
6. 总结
其实并发安全解决起来并不复杂,这问题难在发现这个问题,如果你根本就没有重视这问题,可能在项目运行过程中绝多数情况下是正确的,但如果出现了并发安全问题,可能会很大的损失
但现在讨论的是单节点下的并发安全问题(一个JVM),但在分布式场景下可能又会出现新的问题,那这里说的问题是什么呢?请听下回分析;
现在都说互联网寒冬,其实只要自身技术能力够强,咱们就不怕!我这边专门针对Android开发工程师整理了一套【Android进阶学习视频】、【全套Android面试秘籍】、【Android知识点PDF】。如有需要获取资料文档的朋友,可以点击我的GitHub免费获取!
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
料的朋友,可以点击这里获取](https://bbs.csdn.net/topics/618540462)**
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!