这是我的部分代码:
if (bufferList.size() < 500) {
bufferList.add(song);
} else {
synchronized (this) {
try {
// 为了性能,用SpringJDBC
Date date = new Date();
batchInsertSelective(bufferList);
Date date1 = new Date();
System.out.println("[INFO] 线程\t" + Thread.currentThread().getId() + "\t本次插入所花时间:\t" + (date1.getTime() - date.getTime()));
bufferList.clear();
objectCount += bufferList.size();
} catch (Exception e) {
e.printStackTrace();
logger.error(e.getMessage());
}
}
}
情景:多个线程访问这一段代码,如果缓存List大小大于500就调用batchInsertSelective将数据批量导入数据库,为了测试,我加上了两个时间用来测试insert的时间,并打印。因为加了锁,所以数据库并没有出现重复的问题。但打印的时候问题来了:
[INFO] 线程 57 本次插入所花时间: 1106
[INFO] 线程 89 本次插入所花时间: 0
[INFO] 线程 36 本次插入所花时间: 0
[INFO] 线程 45 本次插入所花时间: 0
[INFO] 线程 76 本次插入所花时间: 0
[INFO] 线程 42 本次插入所花时间: 0
[INFO] 线程 58 本次插入所花时间: 0
[INFO] 线程 86 本次插入所花时间: 0
[INFO] 线程 67 本次插入所花时间: 0
[INFO] 线程 81 本次插入所花时间: 0
[INFO] 线程 64 本次插入所花时间: 0
[INFO] 线程 79 本次插入所花时间: 0
[INFO] 线程 71 本次插入所花时间: 0
[INFO] 线程 88 本次插入所花时间: 0
打印的时候会显示这样(数据库数据没有受到此问题的影响,没有重复值)。
求助大神解答一下。
【求助大佬】关于java并发实际操作中出现的一个问题
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答
- COCO_AS 2017-11-19 14:48关注
不要用 Date, 用Java.lang.System.currentTimeMillis()
Date精确到秒, 用毫秒
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥100 Jenkins自动化部署—悬赏100元
- ¥15 关于#python#的问题:求帮写python代码
- ¥20 MATLAB画图图形出现上下震荡的线条
- ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘
- ¥15 perl MISA分析p3_in脚本出错
- ¥15 k8s部署jupyterlab,jupyterlab保存不了文件
- ¥15 ubuntu虚拟机打包apk错误
- ¥199 rust编程架构设计的方案 有偿
- ¥15 回答4f系统的像差计算
- ¥15 java如何提取出pdf里的文字?