很多时候,我们需要对一个庞大的队列或者二维数组进行处理。这些处理可能是循环的,比如给一个excel多个sheet的联系人列表发邮件。很幼稚的方法就是用一个或者两个FOR循环搞定,对于庞大的数据有得让你等的。最要命的是当你出去喝茶的时候,程序没有处理好抛出Exception了,那你原本的计划任务都会终止。

多线程的好处是比较多的,特别是能装装B,让你从男孩变成男人的感觉。不废话了,我简化了工作中使用的一个多线程框架,做了些扩展,直接上代码:

1:多线程处理线性队列

  1. public static void processLineTask(final List<Object> list, int threadCount){
  2. //确保线程数量不大于队列长度
  3. threadCount = Math.min(threadCount, list.size());
  4. for(int i = 0;i < threadCount;i++){
  5. new Thread(){
  6. public void run(){
  7. while(true){
  8. Object o;
  9. //提取队列元素的时候,需要锁住队列
  10. synchronized(list){
  11. //当队列长度为0的时候,线程逐个结束
  12. if(list.size() == 0){
  13. break;
  14. }
  15. o = list.remove(0);
  16. }
  17. //这里可以写一些对元素o的操作
  18. //……
  19. }
  20. }
  21. }.start();
  22. }
  23. }

2:多线程处理环状队列

  1. public static void processCircleTask(final List<Object> list, int threadCount){
  2. //确保线程数量不大于队列长度
  3. threadCount = Math.min(threadCount, list.size());
  4. for(int i = 0;i < threadCount;i++){
  5. new Thread(){
  6. public void run(){
  7. while(true){
  8. Object o;
  9. //提取队列元素的时候,需要锁住队列
  10. synchronized(list){
  11. o = list.remove(0);
  12. }
  13. //这里可以写一些对元素o的操作
  14. //……
  15. //为防止小环导致循环过快,可以给每个o添加时间属性,如果间隔过小就在此sleep
  16. //把元素放到队列尾部
  17. synchronized(list){
  18. list.add(o);
  19. }
  20. }
  21. }
  22. }.start();
  23. }
  24. }

3:多线程处理二维数组,单线处理

  1. public static void processMultiListTask1(final List<List<Object>> list, int threadCount){
  2. //确保线程数量不大于队列长度
  3. threadCount = Math.min(threadCount, list.size());
  4. for(int i = 0;i < threadCount;i++){
  5. new Thread(){
  6. public void run(){
  7. while(true){
  8. List<Object> listSub;
  9. //提取值,需要锁住对象
  10. synchronized(list){
  11. if(list.size() == 0){
  12. break;
  13. }
  14. listSub = list.remove(0);
  15. }
  16. Object o;
  17. for(int i = 0;i < listSub.size();i++){
  18. o = listSub.get(i);
  19. //这里可以写一些对元素o的操作
  20. //……
  21. }
  22. }
  23. }
  24. }.start();
  25. }
  26. }

4:多线程处理二维数组,交叉处理

  1. public static void processMultiListTask2(final List<List<Object>> list, int threadCount){
  2. //确保线程数量不大于队列长度
  3. threadCount = Math.min(threadCount, list.size());
  4. for(int i = 0;i < threadCount;i++){
  5. new Thread(){
  6. public void run(){
  7. while(true){
  8. Object o;
  9. //提取值,需要锁住对象
  10. synchronized(list){
  11. if(list.size() == 0){
  12. break;
  13. }
  14. if(list.get(0).size() == 0){
  15. list.remove(0);
  16. }
  17. o = list.get(0).remove(0);
  18. }
  19. //这里可以写一些对元素o的操作
  20. //……
  21. }
  22. }
  23. }.start();
  24. }
  25. }

Java多线程处理任务(摘抄)的更多相关文章

  1. Java多线程处理List数据

    实例1: 解决问题:如何让n个线程顺序遍历含有n个元素的List集合 import java.util.ArrayList; import java.util.List; import org.apa ...

  2. java多线程处理任务

    最近用到使用多线程处理给用户发送站内消息的问题,想到使用java自带的线程池进行处理这个问题,具体如下: 定义一个线程: package com.qlwb.util; import org.apach ...

  3. Java面试宝典摘抄

    1,ClassLoader知识 加载流程:当运行一个程序时,JVM启动,运行bootstrap classloader,该classloader加载Java核心API(此时ExtClassLoader ...

  4. java多线程处理

    package com.copyFile; import java.io.BufferedReader;import java.io.File;import java.io.FileReader;im ...

  5. Java 多线程处理[全]

    http://blog.csdn.net/ghsau/article/details/7421217 Java线程(一):线程安全与不安全 http://blog.csdn.net/ghsau/art ...

  6. Java注解知识点摘抄

    Java注解提供了关于代码的一些信息,但并不直接作用于它所注解的代码内容.在这个教程当中,我们将学习Java的注解,如何定制注解,注解的使用以及如何通过反射解析注解. Java1.5引入了注解,当前许 ...

  7. java 内部类(摘抄自网络)

    Java内部类 1.内部类分为成员内部类.静态嵌套类.方法内部类.匿名内部类. 几种内部类的共性: A.内部类仍然是一个独立的类,在编译之后会内部类会被编译成独立的.class文件,但是前面冠以外部类 ...

  8. Java多线程处理某个线程超时的问题

    ExecutorService exec = Executors.newFixedThreadPool(4); List<Future<Integer>> futures = ...

  9. java多线程处理导入数据拆分List集合 同步处理插入数据

    原文:https://www.2cto.com/kf/201612/581174.html import org.apache.log4j.Logger; import org.apache.poi. ...

随机推荐

  1. CTF -bugku-web-web基础$_GET和$_POST

    ---恢复内容开始--- GET那题 就算没有学过php也会看懂if条件语句 于是我们在url后面直接加 ?what = flag 这样echo输出flag POST那题 直接火狐 要装hackbar ...

  2. CodeForces 1000C Covered Points Count(区间线段覆盖问题,差分)

    https://codeforces.com/problemset/problem/1000/C 题意: 有n个线段,覆盖[li,ri],最后依次输出覆盖层数为1~n的点的个数. 思路: 区间线段覆盖 ...

  3. HDU 3484 Matrix Game 枚举暴力

    上次周赛碰到这个题目,居然都没思路,真是不应该啊,起码也应该想到枚举法. 因为题目只允许每一row进行reverse操作,而每两列可以进行交换操作,所以首先把row的变化固定下来,即枚举第一列与第1- ...

  4. Maven--超级 POM

    对于 Maven3,超级 POM 在文件 %MAVEN_HOME%/lib/maven-model-builder-x.x.x.jar 中的 org/apache/maven/model/pom-4. ...

  5. python pandas写入excel文件

    pandas读取.写入csv数据非常方便,但是有时希望通过excel画个简单的图表看一下数据质量.变化趋势并保存,这时候csv格式的数据就略显不便,因此尝试直接将数据写入excel文件. pandas ...

  6. Vue.js——3.增删改查

    vue  写假后台  bootstrap 做的样式 代码 <!DOCTYPE html> <html lang="en"> <head> < ...

  7. JavaScript—面向对象小例子

    什么是面向对象 要是以前别人问我.随口道来,封装继承多态,万物皆对象...一大推.说的自己都以为自己掌握了面向对象.呵呵一笑.确实掌握了 只是不会用..... 什么是面向对象编程 以前 学.Net 虽 ...

  8. 查路由途径 traceroute tracert

    linux 用  traceroute IP windows用 tracert IP 虚拟机下使用无效

  9. zabbix几个配置的关系

  10. C++用libcurl通过HTTP以表单的方式Post数据到服务器

    POST字符串 #include <stdio.h> #include <curl/curl.h> int main(void) { CURL* curl = NULL; CU ...