<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    ゞ沉默是金ゞ

    魚離不開水,但是沒有說不離開哪滴水.
    posts - 98,comments - 104,trackbacks - 0
    This article will discuss about Thread pool that uses single thread to execute tasks. From Java 5.0+ one can get such pool from Executors using following method –
    public static ExecutorService newSingleThreadExecutor()
        Creates an Executor that uses a single worker thread operating off an unbounded queue. (Note however that if this single thread terminates due to a failure during execution prior to shutdown, a new one will take its place if needed to execute subsequent tasks.) Tasks are guaranteed to execute sequentially, and no more than one task will be active at any given time. Unlike the otherwise equivalent newFixedThreadPool(1) the returned executor is guaranteed not to be reconfigurable to use additional threads.



    Example-
    Suppose we have 100 properties files in an application. We have one thread that can read properties file and return a map value.

    Pseudo code – READER THREAD

    Config Reader implements Callable<Map<String, String>
    try{
        // Get the file name in the constructor of thread
        // Check if File exists
        // Read the file and retrun the map object
    }catch(Exception e){
            //release all the resource
            //return null
    }

    Main THREAD-
            // Get a Single thread pool from Executors
     try{
        // Get the list of all properties file in the directory
        // Create a READER THREAD by passing the name of file
        // store the READER thread in the a list
        //release all the thread in one go and get the Map objects
    }catch(Exception e){
                    //release all the resources
                    // print the stack trace
    }finally{
            //shutdown the thread pool
    }

    package com.jovialjava.blog.threads;

    import java.io.File;
    import java.io.FileInputStream;
    import java.util.ArrayList;
    import java.util.List;
    import java.util.Properties;
    import java.util.concurrent.Callable;
    import java.util.concurrent.ExecutorService;
    import java.util.concurrent.Executors;
    import java.util.concurrent.Future;

    class SingleReader implements Callable<Properties> {

        
    private String name = null;

        
    public SingleReader(String name) {
            
    this.name = name;
        }

        
    public Properties call() {
            
    try {
                File f 
    = new File(name);
                Properties prop 
    = new Properties();
                
    if (f.exists() && f.canRead() && f.isFile()) {
                    FileInputStream in 
    = new FileInputStream(f);
                    prop.load(in);
                    
    return prop;
                } 
    else {
                    System.err.println(
    "Please check about this file:[" + f.getAbsolutePath() + "]");
                    
    return null;
                }
            } 
    catch (Exception e) {
                e.printStackTrace();
                
    return null;
            }
        }
    }

    public class SingleThreadPoolExample {
        
    public static String directory = "config";
        
    private static ExecutorService executorPool = null;

        
    public static void main(String args) {
            
    try {
                File dir 
    = new File(directory);
                
    if (dir.isDirectory()) {
                    List
    <Callable<Properties>> fileList = new ArrayList<Callable<Properties>>();
                    String[] files 
    = dir.list();
                    
    /**
                     * Optimization - Single thread executor.
                     
    */
                    executorPool 
    = Executors.newSingleThreadExecutor();

                    
    for (String file : files) {
                        Callable
    <Properties> reader = new SingleReader(dir.getAbsolutePath() + File.separator + file);
                        fileList.add(reader);
                    }
                    List
    <Future<Properties>> results = executorPool.invokeAll(fileList);
                    
    /**
                     * Check how many success and how many failure
                     
    */
                    
    int success = 0, failure = 0;
                    
    for (Future<Properties> result : results) {
                        
    if (result.get() == null) {
                            failure
    ++;
                        } 
    else {
                            success
    ++;
                        }
                    }
                    System.out.println(
    "Total number of files [" + fileList.size() + "]");
                    System.out.println(
    "Success Count [" + success + "]");
                    System.out.println(
    "Failure Count [" + failure + "]");
                } 
    else {
                    
    throw new IllegalArgumentException("There is no such directory name -" + directory);
                }
            } 
    catch (Exception e) {
                e.printStackTrace();
            } 
    finally {
                
    if (executorPool != null) {
                    executorPool.shutdown();
                }
            }
        }

    }
    posted on 2012-08-06 10:49 ゞ沉默是金ゞ 閱讀(994) 評論(1)  編輯  收藏 所屬分類: Java SE

    FeedBack:
    # re: Part 12: java.util.concurrent : SingleThreadPool Example
    2012-08-06 16:25 | NotNolyJava
    覺得這個例子用singleThreadExecutor有點牽強,singleThreadExecutor應該是用來人為的將并行的任務竄行化:一個文件100個任務想讀寫,這個時候將這些任務用singleThreadExecutor竄行話避免讀寫錯亂,但是每個任務的提交不受其他任務的影響,不過樓主用英語寫博客不錯啊,好想把英語學好!  回復  更多評論
      
    主站蜘蛛池模板: 久久久久久精品免费看SSS | 日本人的色道www免费一区| 性xxxxx免费视频播放| 免费观看的毛片手机视频| 人人狠狠综合久久亚洲高清| 亚洲一区二区三区国产精品| 久久99亚洲网美利坚合众国 | 亚州免费一级毛片| 亚洲免费在线观看视频| 亚洲日韩精品无码专区| 午夜成人无码福利免费视频| a毛片视频免费观看影院| aⅴ免费在线观看| 中文字幕亚洲综合小综合在线| 久久久WWW免费人成精品| 亚洲免费在线观看视频| 亚洲av日韩av综合| 久久精品中文字幕免费| 日韩一区二区在线免费观看 | 亚洲av中文无码字幕色不卡| 久久免费视频99| 亚洲成人免费电影| 人妻在线日韩免费视频| 亚洲?V乱码久久精品蜜桃| 日日躁狠狠躁狠狠爱免费视频| a级亚洲片精品久久久久久久| 亚洲一本一道一区二区三区| 99re视频精品全部免费| 亚洲精品tv久久久久久久久久| 伊人久久亚洲综合影院首页| 亚洲成a人一区二区三区| 亚洲免费综合色在线视频| 亚洲精品亚洲人成在线观看下载| 成全视频在线观看免费| 亚洲日韩国产精品乱-久| 国产精品免费观看| 亚洲天堂一区二区三区四区| 特级淫片国产免费高清视频| 中文字幕免费观看视频| 久久精品国产亚洲5555| 国产免费AV片在线观看播放|