2.1. 并发重现
OrderNumGenerator负责生成订单ID,而FileId.nextId的方法是写一个文件,取出文件里面最新的数字,然后+1, 获得结果写入原来的文件,再返回数据(这一步涉及IO的读写操作会占用很多时间,很容易产生并发安全问题)
下面是测试类
模拟50个并发,同时生成订单ID,排序后看输出的结果
可以看出最终的结果里面有大量的重复,如果在真实的项目开发中,这会发生很严重的问题
3. 使用Synchronized解决方案
3.1. 解决原理
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接口比同步方法和同步块提供了更具扩展性的锁操作。
他们允许更灵活的结构,可以具有完全不同的性质,并且可以支持多个相关类的条件对象。
它的优势有:可以使锁更公平,可以使线程在等待锁的时候响应中断,可以让线程尝试获取锁,并在无法获取锁的时候立即返回或者等待一段时间,可以在不同的范围,以不同的顺序获取和释放锁。
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数网络安全工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年网络安全全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上网络安全知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加VX:vip204888 (备注网络安全获取)
体系化!**
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加VX:vip204888 (备注网络安全获取)
[外链图片转存中…(img-l9S78vPr-1712837425370)]