多线程解析报表

2024-09-09 06:38
文章标签 多线程 解析 报表

本文主要是介绍多线程解析报表,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

假如有这样一个需求,当我们需要解析一个Excel里多个sheet的数据时,可以考虑使用多线程,每个线程解析一个sheet里的数据,等到所有的sheet都解析完之后,程序需要提示解析完成。


Way1
join
import java.time.LocalTime;public class Main {public static void main(String[] args) throws InterruptedException {Thread sheet1 = new Thread(new Runnable() {@Overridepublic void run() {System.out.println(LocalTime.now() + " sheet1 begin");try {Thread.sleep(5000);} catch (InterruptedException e) {}System.out.println(LocalTime.now() + " sheet1 finish");}});Thread sheet2 = new Thread(new Runnable() {@Overridepublic void run() {System.out.println(LocalTime.now() + " sheet2 begin");try {Thread.sleep(10000);} catch (InterruptedException e) {}System.out.println(LocalTime.now() + " sheet2 finish");}});System.out.println(LocalTime.now() + " all parser begin");sheet1.start();sheet2.start();sheet1.join();sheet2.join();System.out.print(LocalTime.now() + " all parser finish");}}


Way2
CountDownLatch
import java.time.LocalTime;
import java.util.concurrent.CountDownLatch;public class Main {public static void main(String[] args) throws InterruptedException {CountDownLatch latch =  new CountDownLatch(2);Thread sheet1 = new Thread(new Runnable() {@Overridepublic void run() {System.out.println(LocalTime.now() + " sheet1 begin");try {Thread.sleep(5000);} catch (InterruptedException e) {}System.out.println(LocalTime.now() + " sheet1 finish");latch.countDown(); ;}});Thread sheet2 = new Thread(new Runnable() {@Overridepublic void run() {System.out.println(LocalTime.now() + " sheet2 begin");try {Thread.sleep(10000);} catch (InterruptedException e) {}System.out.println(LocalTime.now() + " sheet2 finish");latch.countDown(); ;}});System.out.println(LocalTime.now() + " all parser begin");sheet1.start();sheet2.start();latch.await();System.out.print(LocalTime.now() + " all parser finish");}}

python

import time
import threadingdef sheet1():print(time.strftime("%H:%M:%S")+ " sheet1 begin")time.sleep(5)print(time.strftime("%H:%M:%S") + " sheet1 end")def sheet2():print(time.strftime("%H:%M:%S")+ " sheet2 begin")time.sleep(10)print(time.strftime("%H:%M:%S") + " sheet2 end")if __name__ == '__main__':print(time.strftime("%H:%M:%S") + " all parser begin")thread1 = threading.Thread(target=sheet1)thread2 = threading.Thread(target=sheet2)thread1.start()thread2.start()thread1.join()thread2.join()print(time.strftime("%H:%M:%S") + " all parser end")


这篇关于多线程解析报表的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1150436

相关文章

Java的IO模型、Netty原理解析

《Java的IO模型、Netty原理解析》Java的I/O是以流的方式进行数据输入输出的,Java的类库涉及很多领域的IO内容:标准的输入输出,文件的操作、网络上的数据传输流、字符串流、对象流等,这篇... 目录1.什么是IO2.同步与异步、阻塞与非阻塞3.三种IO模型BIO(blocking I/O)NI

Python 中的异步与同步深度解析(实践记录)

《Python中的异步与同步深度解析(实践记录)》在Python编程世界里,异步和同步的概念是理解程序执行流程和性能优化的关键,这篇文章将带你深入了解它们的差异,以及阻塞和非阻塞的特性,同时通过实际... 目录python中的异步与同步:深度解析与实践异步与同步的定义异步同步阻塞与非阻塞的概念阻塞非阻塞同步

Redis中高并发读写性能的深度解析与优化

《Redis中高并发读写性能的深度解析与优化》Redis作为一款高性能的内存数据库,广泛应用于缓存、消息队列、实时统计等场景,本文将深入探讨Redis的读写并发能力,感兴趣的小伙伴可以了解下... 目录引言一、Redis 并发能力概述1.1 Redis 的读写性能1.2 影响 Redis 并发能力的因素二、

Spring MVC使用视图解析的问题解读

《SpringMVC使用视图解析的问题解读》:本文主要介绍SpringMVC使用视图解析的问题解读,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Spring MVC使用视图解析1. 会使用视图解析的情况2. 不会使用视图解析的情况总结Spring MVC使用视图

Java使用多线程处理未知任务数的方案介绍

《Java使用多线程处理未知任务数的方案介绍》这篇文章主要为大家详细介绍了Java如何使用多线程实现处理未知任务数,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 知道任务个数,你可以定义好线程数规则,生成线程数去跑代码说明:1.虚拟线程池:使用 Executors.newVir

利用Python和C++解析gltf文件的示例详解

《利用Python和C++解析gltf文件的示例详解》gltf,全称是GLTransmissionFormat,是一种开放的3D文件格式,Python和C++是两个非常强大的工具,下面我们就来看看如何... 目录什么是gltf文件选择语言的原因安装必要的库解析gltf文件的步骤1. 读取gltf文件2. 提

Java中的runnable 和 callable 区别解析

《Java中的runnable和callable区别解析》Runnable接口用于定义不需要返回结果的任务,而Callable接口可以返回结果并抛出异常,通常与Future结合使用,Runnab... 目录1. Runnable接口1.1 Runnable的定义1.2 Runnable的特点1.3 使用Ru

使用EasyExcel实现简单的Excel表格解析操作

《使用EasyExcel实现简单的Excel表格解析操作》:本文主要介绍如何使用EasyExcel完成简单的表格解析操作,同时实现了大量数据情况下数据的分次批量入库,并记录每条数据入库的状态,感兴... 目录前言固定模板及表数据格式的解析实现Excel模板内容对应的实体类实现AnalysisEventLis

JAVA封装多线程实现的方式及原理

《JAVA封装多线程实现的方式及原理》:本文主要介绍Java中封装多线程的原理和常见方式,通过封装可以简化多线程的使用,提高安全性,并增强代码的可维护性和可扩展性,需要的朋友可以参考下... 目录前言一、封装的目标二、常见的封装方式及原理总结前言在 Java 中,封装多线程的原理主要围绕着将多线程相关的操

Java的volatile和sychronized底层实现原理解析

《Java的volatile和sychronized底层实现原理解析》文章详细介绍了Java中的synchronized和volatile关键字的底层实现原理,包括字节码层面、JVM层面的实现细节,以... 目录1. 概览2. Synchronized2.1 字节码层面2.2 JVM层面2.2.1 ente