本文实例讲述了Java实现的并发任务处理方法。分享给大家供大家参考,具体如下:

    public void init() {

super.init();

this.ioThreadPool = new ThreadPoolExecutor(50, 50, Long.MAX_VALUE, TimeUnit.SECONDS, new java.util.concurrent.LinkedTransferQueue<Runnable>(), new ThreadFactory() {

AtomicLong id = new AtomicLong();

@Override

public Thread newThread(final Runnable r) {

Thread t = new Thread(new Runnable() {

@Override

public void run() {

try {

r.run();

} catch (RuntimeException e) {

logger.error("执行IO异常", e);

throw e;

}

}

});

t.setDaemon(true);

t.setName("FootballService-IO-" + id.getAndIncrement());

return t;

}

});

}

//从fdate到tdate, 结果: 日期 30个区的创建角色总和

public Map<String, Long> countCreateRole(String fdate, String tdate, final String channel, Map<String, Object> gameConfig) throws Exception {

// 只读数据不需要处理并发

final Map<String, String> param = new HashMap<String, String>();

param.put("fdate", fdate);

param.put("tdate", tdate);

param.put("channel", channel);

final Map<String, Long> date_count = new HashMap<String, Long>();

final List<String> zones = (List<String>) gameConfig.get("areas");

Set<String> dateSet = JdbcTool.getDateRangeByDay(fdate, tdate, "yyyy-MM-dd");

List<Future<Void>> tasks = new ArrayList<>(zones.size());

for (String date : dateSet) {

final String _date = date;

tasks.add(publicThread.submit(new Callable<Void>() {

@Override

public Void call() {

final AtomicLong count = new AtomicLong();

List<Future<Void>> subTasks = new ArrayList<>(zones.size());

for (String _zone : zones) {

final String zone = _zone;

subTasks.add(ioThreadPool.submit(new Callable<Void>() {

@Override

public Void call() throws Exception {

JdbcTemplate _jdbcTemplate = dataSourceManager.getJdbcTemplate(zone);

String database = dataSourceManager.getDatabase(zone);

String _count = mget(CacheConstant.RZRoleCreateCount, zone + "#" + _date + "#" + channel + "#");

if (_count == null) {

StringBuilder sb = new StringBuilder();

sb.append("SELECT count(roleId) as count ");

sb.append("from " + database + "_log.role ");

sb.append("WHERE DATE(createTime)='" + _date + "' ");

if (param.get("channel") != null) {

sb.append(" AND channelId = '" + channel + "' ");

}

long queryForLong = _jdbcTemplate.queryForLong(sb.toString());

count.addAndGet(queryForLong);

mput(CacheConstant.RZRoleCreateCount, zone + "#" + _date + "#" + channel + "#", queryForLong + "");

} else {

count.addAndGet(Long.valueOf(_count));

}

return null;

}

}));

}

for (Future<Void> task : subTasks) {

try {

task.get();

} catch (Exception e) {

throw new RuntimeException(e);

}

}

synchronized (date_count) {

date_count.put(_date, count.get());

}

return null;

}

}));

}

for (Future<Void> task : tasks) {

task.get();

}

return date_count;

}

@PreDestroy

public void destroy() {

this.ioThreadPool.shutdownNow();

}

Java实现的并发任务处理实例的更多相关文章

  1. JAVA 多线程和并发学习笔记(三)

    Java并发编程中使用Executors类创建和管理线程的用法 1.类 Executors Executors类可以看做一个“工具类”.援引JDK1.6 API中的介绍: 此包中所定义的 Execut ...

  2. JAVA多线程和并发基础面试问答(转载)

    JAVA多线程和并发基础面试问答 原文链接:http://ifeve.com/java-multi-threading-concurrency-interview-questions-with-ans ...

  3. [转] JAVA多线程和并发基础面试问答

    JAVA多线程和并发基础面试问答 原文链接:http://ifeve.com/java-multi-threading-concurrency-interview-questions-with-ans ...

  4. JAVA多线程和并发基础面试问答

    转载: JAVA多线程和并发基础面试问答 多线程和并发问题是Java技术面试中面试官比较喜欢问的问题之一.在这里,从面试的角度列出了大部分重要的问题,但是你仍然应该牢固的掌握Java多线程基础知识来对 ...

  5. 【多线程】JAVA多线程和并发基础面试问答(转载)

    JAVA多线程和并发基础面试问答 原文链接:http://ifeve.com/java-multi-threading-concurrency-interview-questions-with-ans ...

  6. java处理高并发高负载类网站的优化方法

    java处理高并发高负载类网站中数据库的设计方法(java教程,java处理大量数据,java高负载数据) 一:高并发高负载类网站关注点之数据库 没错,首先是数据库,这是大多数应用所面临的首个SPOF ...

  7. (转)JAVA多线程和并发基础面试问答

    JAVA多线程和并发基础面试问答 原文链接:http://ifeve.com/java-multi-threading-concurrency-interview-questions-with-ans ...

  8. Java多线程与并发模型之锁

    这是一篇总结Java多线程开发的长文.文章是从Java创建之初就存在的synchronized关键字引入,对Java多线程和并发模型进行了探讨.希望通过此篇内容的解读能帮助Java开发者更好的理清Ja ...

  9. Java编程思想 - 并发

    前言 Q: 为什么学习并发? A: 到目前为止,你学到的都是有关顺序编程的知识,即程序中的所有事物在任意时刻都只能执行一个步骤. A: 编程问题中相当大的一部分都可以通过使用顺序编程来解决,然而,对于 ...

随机推荐

  1. Spring MVC框架实例

    Spring  MVC 背景介绍 Spring 框架提供了构建 Web 应用程序的全功能 MVC 模块.使用 Spring 可插入的 MVC 架构,能够选择是使用内置的 Spring Web 框架还是 ...

  2. 8.spring-boot配置log4j

    转自:https://www.cnblogs.com/qixing/p/7763582.html <dependency> <groupId>org.springframewo ...

  3. JQuery map()函数

    DOM.map(callback(index,domElement)); 对匹配元素执行函数对象. 返回值是 jQuery 封装的数组,使用 get() 来处理返回的对象以得到基础的数组. 返回数据类 ...

  4. vue.js的基础与语法

    Vue的实例 创建第一个实例: {{}} 被称之为插值表达式.可以用来进行文本插值. <!DOCTYPE html> <html lang="en"> &l ...

  5. GO语言学习(十三)Go 语言变量作用域

    Go 语言变量作用域 作用域为已声明标识符所表示的常量.类型.变量.函数或包在源代码中的作用范围. Go 语言中变量可以在三个地方声明: 函数内定义的变量称为局部变量 函数外定义的变量称为全局变量 函 ...

  6. Socket 长连接与短连接,心跳

    长连接与短连接 所谓长连接,指在一个TCP连接上可以连续发送多个数据包,在TCP连接保持期间,如果没有数据包发送,需要双方发检测包以维持此连接,一般需要自己做在线维持. 短连接是指通信双方有数据交互时 ...

  7. 【codeforces 434 div 1 A】Did you mean...

    [链接]h在这里写链接 [题意] 让你维护一段序列. 这段序列,不会出现连续3个以上的辅音. (或者一块全是辅音则也可以) (用空格可以断开连续次数); 要求空格最小. [题解] 模拟着,别让它出现连 ...

  8. 安装后,挂载c盘失败

    现象: 安装后,window C盘mount失败 错误内容如下: Error mounting: mount exited with exit code 13: ntfs_attr_pread_i: ...

  9. js进阶 12-18 jquery如何实现自定义右键菜单(把问题分细)

    js进阶 12-18  jquery如何实现自定义右键菜单(把问题分细) 一.总结 一句话总结:用鼠标右键事件contextmenu,阻止系统默认事件,让做好的右键菜单显示出来,并且显示在我们出现的位 ...

  10. 从零开始使用git第二篇:git的日常操作

    从零开始使用git 第二篇:git的日常操作 第一篇:从零开始使用git第一篇:下载安装配置 第二篇:从零开始使用git第二篇:git实践操作 第三篇:从零开始使用git第三篇:git撤销操作.分支操 ...