ゞ沉默是金ゞ

          魚離不開水,但是沒有說不離開哪滴水.
          posts - 98,comments - 104,trackbacks - 0
          <2012年8月>
          2930311234
          567891011
          12131415161718
          19202122232425
          2627282930311
          2345678

          常用鏈接

          留言簿(3)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          搜索

          •  

          最新評論

          閱讀排行榜

          評論排行榜

          This article will discuss about Thread pool that can schedule threads to run after a specified interval of time. From Java 5.0+ one can get such pool from Executors using following method –

          public static ScheduledExecutorService 
                 newScheduledThreadPool(int corePoolSize)
              Creates a thread pool that can schedule commands to run after a given delay, or to execute periodically.

          The return type of this method (return type of thread pool) is ScheduledExecutorService.Some of the salient features of ScheduledExecutorService are –
          1.         Schedule a Callable or Runnable to run once with a fixed delay after submission
          2.         Schedule a Runnable to run periodically at a fixed rate
          3.         Schedule a Runnable to run periodically with a fixed delay between executions
          4.         Submission returns a ScheduledFutureTask handle which can be used to cancel the task
          5.  .Like Timer, but supports pooling


          Example:
          1. Suppose we are building a Bank check processing system. Here is the process –
          2.  Every local branch collect cheques and create a txt file contain cheque info.
          3.  A service runs which copy the cheque txt file from local branch to main server.
          4.  A Local service runs on server which check if any file has received and notify the cheque Clearing process.


          We will try to make “Local Service”, which check the file reception and “Copying process” Which copy file from client machine to Server.
          Pseudo Code-

          //Define Local & Copying service running interval time in Seconds
          //Make an ScheduledThreadPool with pool size 2
          try{
              // Make Local Service thread
              // Make Copying process thread
              // Scheduled Both thread to run at regular interval
          }catch(Exception e){
           //release all resources
          }

          LocalService Thread-
          Try{
                  //Check if directory exists
                  //Check if any file exists in directory
                  //return status
          }catch(Exception e){
                  //Print necessary exception
          }

          Copying Process Thread-
          Try{
             // Check if File existin on remote server
             // Copy the file to main server
          }catch(Exception e){
                  //Print necessary exception
          }

          package com.jovialjava.blog.threads;

          import java.io.File;
          import java.util.concurrent.Executors;
          import java.util.concurrent.ScheduledExecutorService;
          import java.util.concurrent.TimeUnit;

          //LOCAL SERVICE THREAD
          class LocalService implements Runnable {

              
          private String DIRECTORY = null;

              
          public LocalService(String DIRECTORY) {
                  
          this.DIRECTORY = DIRECTORY;
              }

              
          public void run() {
                  
          try {
                      File dir 
          = new File(this.DIRECTORY);
                      
          if (dir.isDirectory()) {
                          
          if (dir.list().length > 0) {
                              System.out.println(
          "FILE EXISTS");
                          }
                      } 
          else {
                          System.err.println(
          "NO SUCH DIRECTORY [" + dir.getAbsolutePath() + "] exists");
                      }
                  } 
          catch (Exception e) {
                      e.printStackTrace();
                  }
              }
          }

          // COPYING SERVICE THREAD
          class CopyService implements Runnable {

              
          private String REMOTE_DIR = null;
              
          private String LOCAL_DIR = null;

              
          public CopyService(String remoteDir, String localDir) {
                  
          this.REMOTE_DIR = remoteDir;
                  
          this.LOCAL_DIR = localDir;
              }

              
          public void run() {
                  
          try {
                      File remote 
          = new File(this.REMOTE_DIR);
                      File local 
          = new File(this.LOCAL_DIR);
                      
          if (remote.isDirectory() && local.isDirectory()) {
                          
          if (remote.list().length > 0) {
                              System.out.println(
          "REMOTE FILE FOUND, COPYING");
                              
          // --- Call the file copying method.
                          } else {
                              System.out.println(
          "NO REMOTE FILE FOUND");
                          }
                      } 
          else {
                          System.err.println(
          "PLEASE CHECK DIRECTORY [" + remote.getAbsolutePath() + " OR/AND"
                                  
          + local.getAbsolutePath() + "] existence");
                      }
                  } 
          catch (Exception e) {
                      e.printStackTrace();
                  }
              }
          }

          public class ScheduledExample {

              
          private static final ScheduledExecutorService executor = Executors.newScheduledThreadPool(2);
              
          private static final int LOCAL_INTERVAL = 5, COPY_INTERVAL = 2;
              
          private static final String REMOTE_DIR = "REMOTE", LOCAL_DIR = "LOCAL";

              
          public static void main(String args) {
                  Runnable localService 
          = new LocalService(LOCAL_DIR);
                  Runnable remoteService 
          = new CopyService(REMOTE_DIR, LOCAL_DIR);
                  
          try {
                      executor.scheduleWithFixedDelay(localService, 
          0, LOCAL_INTERVAL, TimeUnit.SECONDS);
                      executor.scheduleWithFixedDelay(remoteService, 
          0, COPY_INTERVAL, TimeUnit.SECONDS);
                  } 
          catch (Exception e) {
                      e.printStackTrace();
                  }
              }
          }
          posted on 2012-08-06 10:45 ゞ沉默是金ゞ 閱讀(867) 評論(0)  編輯  收藏 所屬分類: Java SE
          主站蜘蛛池模板: 义马市| 巨鹿县| 宜阳县| 盖州市| 桓台县| 西城区| 松阳县| 尼木县| 石林| 浦东新区| 宕昌县| 交口县| 连江县| 修武县| 同心县| 方正县| 佳木斯市| 清流县| 临江市| 巴彦淖尔市| 武穴市| 潜山县| 泰兴市| 页游| 镇巴县| 沙坪坝区| 孟州市| 华池县| 泗水县| 扎兰屯市| 陆良县| 黄浦区| 红安县| 新源县| 姜堰市| 南乐县| 万山特区| 隆化县| 孙吴县| 义乌市| 通州市|