Java多线程处理任务(摘抄)
很多时候,我们需要对一个庞大的队列或者二维数组进行处理。这些处理可能是循环的,比如给一个excel多个sheet的联系人列表发邮件。很幼稚的方法就是用一个或者两个FOR循环搞定,对于庞大的数据有得让你等的。最要命的是当你出去喝茶的时候,程序没有处理好抛出Exception了,那你原本的计划任务都会终止。
多线程的好处是比较多的,特别是能装装B,让你从男孩变成男人的感觉。不废话了,我简化了工作中使用的一个多线程框架,做了些扩展,直接上代码:
1:多线程处理线性队列
- public static void processLineTask(final List<Object> list, int threadCount){
- //确保线程数量不大于队列长度
- threadCount = Math.min(threadCount, list.size());
- for(int i = 0;i < threadCount;i++){
- new Thread(){
- public void run(){
- while(true){
- Object o;
- //提取队列元素的时候,需要锁住队列
- synchronized(list){
- //当队列长度为0的时候,线程逐个结束
- if(list.size() == 0){
- break;
- }
- o = list.remove(0);
- }
- //这里可以写一些对元素o的操作
- //……
- }
- }
- }.start();
- }
- }
2:多线程处理环状队列
- public static void processCircleTask(final List<Object> list, int threadCount){
- //确保线程数量不大于队列长度
- threadCount = Math.min(threadCount, list.size());
- for(int i = 0;i < threadCount;i++){
- new Thread(){
- public void run(){
- while(true){
- Object o;
- //提取队列元素的时候,需要锁住队列
- synchronized(list){
- o = list.remove(0);
- }
- //这里可以写一些对元素o的操作
- //……
- //为防止小环导致循环过快,可以给每个o添加时间属性,如果间隔过小就在此sleep
- //把元素放到队列尾部
- synchronized(list){
- list.add(o);
- }
- }
- }
- }.start();
- }
- }
3:多线程处理二维数组,单线处理
- public static void processMultiListTask1(final List<List<Object>> list, int threadCount){
- //确保线程数量不大于队列长度
- threadCount = Math.min(threadCount, list.size());
- for(int i = 0;i < threadCount;i++){
- new Thread(){
- public void run(){
- while(true){
- List<Object> listSub;
- //提取值,需要锁住对象
- synchronized(list){
- if(list.size() == 0){
- break;
- }
- listSub = list.remove(0);
- }
- Object o;
- for(int i = 0;i < listSub.size();i++){
- o = listSub.get(i);
- //这里可以写一些对元素o的操作
- //……
- }
- }
- }
- }.start();
- }
- }
4:多线程处理二维数组,交叉处理
- public static void processMultiListTask2(final List<List<Object>> list, int threadCount){
- //确保线程数量不大于队列长度
- threadCount = Math.min(threadCount, list.size());
- for(int i = 0;i < threadCount;i++){
- new Thread(){
- public void run(){
- while(true){
- Object o;
- //提取值,需要锁住对象
- synchronized(list){
- if(list.size() == 0){
- break;
- }
- if(list.get(0).size() == 0){
- list.remove(0);
- }
- o = list.get(0).remove(0);
- }
- //这里可以写一些对元素o的操作
- //……
- }
- }
- }.start();
- }
- }
Java多线程处理任务(摘抄)的更多相关文章
- Java多线程处理List数据
实例1: 解决问题:如何让n个线程顺序遍历含有n个元素的List集合 import java.util.ArrayList; import java.util.List; import org.apa ...
- java多线程处理任务
最近用到使用多线程处理给用户发送站内消息的问题,想到使用java自带的线程池进行处理这个问题,具体如下: 定义一个线程: package com.qlwb.util; import org.apach ...
- Java面试宝典摘抄
1,ClassLoader知识 加载流程:当运行一个程序时,JVM启动,运行bootstrap classloader,该classloader加载Java核心API(此时ExtClassLoader ...
- java多线程处理
package com.copyFile; import java.io.BufferedReader;import java.io.File;import java.io.FileReader;im ...
- Java 多线程处理[全]
http://blog.csdn.net/ghsau/article/details/7421217 Java线程(一):线程安全与不安全 http://blog.csdn.net/ghsau/art ...
- Java注解知识点摘抄
Java注解提供了关于代码的一些信息,但并不直接作用于它所注解的代码内容.在这个教程当中,我们将学习Java的注解,如何定制注解,注解的使用以及如何通过反射解析注解. Java1.5引入了注解,当前许 ...
- java 内部类(摘抄自网络)
Java内部类 1.内部类分为成员内部类.静态嵌套类.方法内部类.匿名内部类. 几种内部类的共性: A.内部类仍然是一个独立的类,在编译之后会内部类会被编译成独立的.class文件,但是前面冠以外部类 ...
- Java多线程处理某个线程超时的问题
ExecutorService exec = Executors.newFixedThreadPool(4); List<Future<Integer>> futures = ...
- java多线程处理导入数据拆分List集合 同步处理插入数据
原文:https://www.2cto.com/kf/201612/581174.html import org.apache.log4j.Logger; import org.apache.poi. ...
随机推荐
- HTTP协议(三):状态码
前言 作者说:在上一节的内容中,HTTP大佬介绍了他是怎么让服务器和用户达成信息交互的,详细的说明了连接建立过程中用到的一些基本的技术原理,包括请求报文响应报文.建立持久化连接用的Cookie技术等内 ...
- form——验证器Validators
form表单最大的作用就是验证功能了,通过cleaned_data清洗,我们可以获取传来的值,通过参数.验证器.自定义验证方法,我们可以做到很多的验证. 验证器可用于在不同类型的字段之间重用验证逻辑. ...
- GoF 23种设计模式概述
本文的结构: 一.设计模式总览 二.创建型设计模式 Creational Patterns 三.结构型设计模式 Structural Patterns 四.行为型设计模式 Behavioral Pat ...
- UVA 11732 链表+字典树
因为字符集比较大,所以就不能用简单字典树,在字典树里面,用链表进行存储.这个倒是不难,练了下手 统计的时候还是有点难搞,因为要算所有的两两比较的次数之和,对分叉处进行计算,注意细节 #include ...
- vue点击变色
<template> <div> <router-link to="/w1">点击回去</router-link> <div ...
- 出现UnboundLocalError: local variable 'a' referenced before assignment异常的情况与解决方法
出现UnboundLocalError: local variable ‘a’ referenced before assignment异常的情况与解决方法字面意思:局部变量赋值前被引用原因:局部变量 ...
- (转载)JVM中的内存模型与垃圾回收
转载自微信公众号:Java高级架构(Java-jiagou)-----看完这篇文章,我奶奶都知道JVM中的内存模型与垃圾回收了! 六.内存模型 6.1 内存模型与运行时数据区 Java虚拟机在执行J ...
- Linux CMD 笔记 & 正则表达式
一.linux bash 1. 进程名查找kill ps -ef | grep xxxx| grep -v grep| cut -c 9-15 | xargs kill -9 2.端口号kill 占用 ...
- JAVA 算法练习(二)
和上次一样,虽说用 java 语言,但有 c 的基础一样可以看懂哦. 机器人走方格问题Ⅰ 题目概述 有一个XxY的网格,一个机器人只能走格点且只能向右或向下走,要从左上角走到右下角.请设计一个算法,计 ...
- nginx_tcp_proxy代理酸酸乳
一.安装低版本的nginx(高版本不支持tcp代理模块:nginx_tcp_proxy_module)Nginx默认只支持http反向代理,要支持tcp反向代理,需在编译时增加tcp代理模块[ngin ...