国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

Java實現的并發任務處理實例

2019-11-26 14:49:04
字體:
來源:轉載
供稿:網友

本文實例講述了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;}@PreDestroypublic void destroy() { this.ioThreadPool.shutdownNow();}

希望本文所述對大家java程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宜兰县| 郯城县| 靖边县| 青河县| 平遥县| 习水县| 榕江县| 通化市| 姚安县| 高安市| 五家渠市| 金寨县| 贞丰县| 札达县| 伽师县| 新龙县| 榕江县| 郴州市| 绥滨县| 承德市| 平乐县| 安国市| 崇州市| 萨嘎县| 汉中市| 余江县| 比如县| 旺苍县| 淳化县| 资源县| 金门县| 涿鹿县| 小金县| 绍兴市| 青岛市| 民勤县| 垣曲县| 嵊州市| 瑞金市| 阳新县| 漳浦县|