Callable Future 实现多线程按照顺序上传文件

/**

* 异步上传 BiopsyFlow 中的所有视频和音频文件到暂存服务器

*/

private List<String> uploadBiopsyFlowFiles(BiopsyFlow biopsyFlow, SyncFile SyncFile) {

List<String> fileBase64List = syncFile.getFileBase64List();

if (CollectionUtils.isEmpty(syncFile.getFileBase64List())) {

log.info("没有文件需要上传");

return Collections.emptyList();

}

log.info("上传文件数量:{}", fileBase64List.size());

List<Callable<String>> tasks = new ArrayList<>();

for (String file : fileBase64List) {

Callable<String> task = () -> {

log.debug("上传线程:{}", Thread.currentThread().getName());

try {

return fileDealUtils.uploadTxFile(file, biopsyFlow.getTransId());

} catch (Exception e) {

log.error("文件上传失败, 异常={}", e.getMessage());

return null;

}

};

tasks.add(task);

}

// 使用公共线程池提交任务

List<Future<String>> futures = new ArrayList<>();

try {

for (Callable<String> task : tasks) {

Future<String> future = pullVideoTaskExecutor.submit(task);

futures.add(future);

}

// 按顺序获取结果

List<String> fileIds = new ArrayList<>();

for (Future<String> future : futures) {

try {

String fileId = future.get();

if (fileId != null) {

fileIds.add(fileId);

} else {

log.error("文件上传失败: 返回的文件ID为空");

return Collections.emptyList();

}

} catch (Exception e) {

log.error("文件上传失败: 异常={}", e.getMessage());

return Collections.emptyList();

}

}

// // TODO 测试下载,上线之前删除

// for (String fileId : fileIds) {

// String base64 = fileDealUtils.testDownMp4(fileId);

// log.info("下载的文件id:{}, 对应下载的视频base64:{}", fileId,base64.substring(0,100));

// }

return fileIds;

} catch (Exception e) {

log.error("任务执行过程中发生异常", e);

return Collections.emptyList();

}

}

相关推荐
武子康21 分钟前
Java-80 深入浅出 RPC Dubbo 动态服务降级:从雪崩防护到配置中心秒级生效
java·分布式·后端·spring·微服务·rpc·dubbo
YuTaoShao3 小时前
【LeetCode 热题 100】131. 分割回文串——回溯
java·算法·leetcode·深度优先
源码_V_saaskw3 小时前
JAVA图文短视频交友+自营商城系统源码支持小程序+Android+IOS+H5
java·微信小程序·小程序·uni-app·音视频·交友
超浪的晨3 小时前
Java UDP 通信详解:从基础到实战,彻底掌握无连接网络编程
java·开发语言·后端·学习·个人开发
双力臂4044 小时前
Spring Boot 单元测试进阶:JUnit5 + Mock测试与切片测试实战及覆盖率报告生成
java·spring boot·后端·单元测试
Edingbrugh.南空4 小时前
Aerospike与Redis深度对比:从架构到性能的全方位解析
java·开发语言·spring
QQ_4376643145 小时前
C++11 右值引用 Lambda 表达式
java·开发语言·c++
永卿0015 小时前
设计模式-迭代器模式
java·设计模式·迭代器模式
誰能久伴不乏5 小时前
Linux如何执行系统调用及高效执行系统调用:深入浅出的解析
java·服务器·前端
慕y2746 小时前
Java学习第七十二部分——Zookeeper
java·学习·java-zookeeper