多线程返回计时问题代码案例

复制代码
@Component
@Slf4j
@Async
public class ThreadSaveDigCategory {

    private static final int BATCH_COUTN = 1000;

    @Autowired
    private Mapper mapper;

    public Future<Boolean> saveDigCategoryDatas(List<DigCategoryData> digCategoryDataList){
        //开始计时
        long startTime = System.currentTimeMillis();

//        mapper.saveDigCategoryData(digCategoryDataList);
        //数据分批处理
        List<List<DigCategoryData>> batchList = BathProcessUtil.batchList(digCategoryDataList, BATCH_COUTN);
        for (List<DigCategoryData> batch : batchList){
            mapper.saveDigCategoryData(batch);
        }

        //endTime
        long endTime = System.currentTimeMillis();
        Calendar calendar = Calendar.getInstance();
        calendar.setTimeInMillis(endTime-startTime);
        log.info("耗时: " + calendar.get(Calendar.MINUTE) + "分 " + calendar.get(Calendar.SECOND) + "秒 " +
                calendar.get(Calendar.MILLISECOND) + " 微秒" + "-" + "数据保存成功");

        return new AsyncResult<>(true);
    }
}
相关推荐
~~李木子~~23 分钟前
Windows软件自动扫描与分类工具 - 技术文档
windows·分类·数据挖掘
QiTinna28 分钟前
系统运维Day02_数据同步服务
linux·同步·rsync
阿猿收手吧!43 分钟前
【Linux网络】shutdown()与close()的区别
linux·网络
LCG元1 小时前
Linux 磁盘管理从入门到精通:LVM 扩容实战案例
linux
liu****1 小时前
12.线程(二)
linux·开发语言·c++·1024程序员节
咯哦哦哦哦1 小时前
vscode arm交叉编译 中 cmakeTools 编译器设置
linux·arm开发·vscode·编辑器
-指短琴长-1 小时前
Qt的下载和安装【Windows】
开发语言·windows·qt
梁正雄2 小时前
6、prometheus资源规划
运维·服务器·服务发现·prometheus·监控
晨曦之旅2 小时前
零成本体验云计算!阿贝云免费服务器深度测评
运维·服务器·云计算
工具人55552 小时前
Linux 抓取 RAM Dump 完整指南
linux·运维·安全