国产探花免费观看_亚洲丰满少妇自慰呻吟_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程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 通山县| 南丰县| 江口县| 香河县| 来宾市| 河池市| 亚东县| 盘锦市| 孝昌县| 万盛区| 佛坪县| 凌云县| 凤冈县| 遂平县| 宁波市| 漳州市| 闻喜县| 门源| 威远县| 金山区| 景洪市| 亳州市| 黄平县| 西乌珠穆沁旗| 上蔡县| 汉中市| 准格尔旗| 沙坪坝区| 灌阳县| 贵州省| 临夏县| 淅川县| 太和县| 祁连县| 弥勒县| 洮南市| 通山县| 常德市| 通山县| 遂昌县| 通山县|