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

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

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

    春風博客

    春天里,百花香...

    導航

    <2007年6月>
    272829303112
    3456789
    10111213141516
    17181920212223
    24252627282930
    1234567

    統計

    公告

    MAIL: junglesong@gmail.com
    MSN: junglesong_5@hotmail.com

    Locations of visitors to this page

    常用鏈接

    留言簿(11)

    隨筆分類(224)

    隨筆檔案(126)

    個人軟件下載

    我的其它博客

    我的鄰居們

    最新隨筆

    搜索

    積分與排名

    最新評論

    閱讀排行榜

    評論排行榜

    使用回調和線程處理一個耗時響應過程

    現在程序中有許多涉及長耗時響應過程的處理,比如訪問WebService,遠程調用,復雜處理等,如果我們使用直接順序執行的方式進行處理有可能導致界面停頓,響應停止,無謂等待等缺陷,這是不應該的。

    一個耗時響應過程應該采用回調和線程來處理,具體就是把原來的順序執行修改為異步方式,并讓被調用者調用調用者以獲得執行結果。在附件的例子中,Viewer就是調用者,它代表界面,而LongTimeResponse是被調用者,它內部用線程啟動一個耗時過程,執行完畢再通知調用者。

    Viewer類代碼如下:

    public class Viewer{
        
    private int count;
        
        
    public Viewer(int count){
            
    this.count=count;
        }

        
        
    public void printNewCount(int newCount){
            System.out.println(
    "New Count="+newCount);
        }


        
    public int getCount() {
            
    return count;
        }


        
    public void setCount(int count) {
            
    this.count = count;
        }

    }


    LongTimeResponse類代碼如下,可以看出,它之所以能回調調用者,是因為其內部有調用者的引用viewer,在其構造函數中viewer被賦上了值:

    package com.sitinspring;

    public class LongTimeResponse implements Runnable{
        
    private Viewer viewer;
        
    private int count;
        
        
    public LongTimeResponse(Viewer viewer){
            
    this.viewer=viewer;
            
    this.count=viewer.getCount();
            
            caculateNewCount();
        }

        
        
    private void caculateNewCount(){
            Thread thread
    =new Thread(this);
            thread.start();
        }

        
        
    public void run(){
            
    try{
                Thread.sleep(
    10000);    
            }

            
    catch(Exception ex){
                ex.printStackTrace();
            }

            
            viewer.printNewCount(count
    *count*count);
        }

    }

     

    調用過程如下:

            Viewer viewer=new Viewer(10);
            LongTimeResponse longTimeResponse
    =new LongTimeResponse(viewer);        
            viewer.printNewCount(
    123);


    執行起來可以看出,程序先輸出了
    New Count=123
    過了十秒,才輸出:
    New Count=1000

    這說明,程序是異步執行的,耗時過程沒有影響到主干程序的運行,而耗時過程完成后,才把返回結果通知了調用者,主干程序沒有受到耗時過程的影響,因此也就不會導致界面停頓,響應停止,無謂等待等缺陷。

    以上就是使用回調和線程處理一個耗時響應的整個過程。

    這里可下載整個程序:
    http://www.tkk7.com/Files/sitinspring/Callback20070628133516.zip

    例程2:
    http://www.tkk7.com/Files/sitinspring/MVCThreadCallback.rar

    posted on 2007-06-28 13:49 sitinspring 閱讀(2682) 評論(6)  編輯  收藏 所屬分類: 線程Thread

    評論

    # re: 使用回調和線程處理一個耗時響應過程 2007-06-29 10:59 我為J狂

    講得簡單明了,是篇好文章。  回復  更多評論   

    # re: 使用回調和線程處理一個耗時響應過程 2007-06-30 12:37 L

    這種東西都應該用FutureTask來做了。。  回復  更多評論   

    # re: 使用回調和線程處理一個耗時響應過程 2007-06-30 13:20 sitinspring

    謝謝樓上指教.  回復  更多評論   

    # re: 使用回調和線程處理一個耗時響應過程[未登錄] 2008-01-13 11:49

    在1.5以上的版本當然可以使用 future task
    個人還沒有發現 new thread 和 future task 的在應用時的主要區別  回復  更多評論   

    # re: 使用回調和線程處理一個耗時響應過程[未登錄] 2008-01-13 11:52

    順便說一句
    一般的情況下程序性能的瓶頸并不是future task 和 new thread 的區別
    更加應該把注意力放在其它耗時的代碼上面 ex 業務操作 數據結構的重組......  回復  更多評論   

    # re: 使用回調和線程處理一個耗時響應過程 2009-03-13 18:10 wangmogang

    頂  回復  更多評論   


    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    sitinspring(http://www.tkk7.com)原創,轉載請注明出處.
    主站蜘蛛池模板: 亚洲毛片免费视频| 日韩一级免费视频| 狠狠色伊人亚洲综合网站色| 国产精品无码一区二区三区免费 | 无码免费午夜福利片在线| 亚洲av色香蕉一区二区三区| 亚洲人成精品久久久久| 嘿嘿嘿视频免费网站在线观看| 国产亚洲精品成人久久网站| 亚洲av无码成人黄网站在线观看| 在人线av无码免费高潮喷水| 一级一黄在线观看视频免费| 亚洲视频欧洲视频| 亚洲精品A在线观看| 69av免费视频| 两个人日本免费完整版在线观看1| 亚洲av乱码一区二区三区香蕉| 亚洲日韩在线观看| 欧洲精品成人免费视频在线观看| 成在人线av无码免费高潮水| 亚洲色大成网站www永久网站| 亚洲va久久久噜噜噜久久| 国产精品免费看香蕉| 一级毛片不卡片免费观看| 日韩在线视频免费| 国产精品亚洲四区在线观看| 情人伊人久久综合亚洲| 国产一级做a爱免费视频| 性xxxxx免费视频播放| a级片在线免费看| 美女视频黄频a免费观看| 亚洲不卡中文字幕| 久久久久亚洲Av片无码v| 亚洲av无码国产精品色在线看不卡| jjizz全部免费看片| 香蕉免费一区二区三区| 成人a毛片免费视频观看| 亚洲AV无码AV男人的天堂不卡 | a级毛片免费全部播放无码| 久久久久久亚洲精品无码| 亚洲一区二区三区免费观看|