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

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

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

    隨筆 - 20  文章 - 57  trackbacks - 0
    <2015年5月>
    262728293012
    3456789
    10111213141516
    17181920212223
    24252627282930
    31123456

    常用鏈接

    留言簿(2)

    隨筆分類

    隨筆檔案

    文章分類

    文章檔案

    51CTO

    搜索

    •  

    最新評論

    閱讀排行榜

    評論排行榜


            Java線程類有兩種實現方式,第一種就是繼承Thread類,另一種是現實Runnable接口。這兩種實現方式的區別很大,下面就說一下它們之間到底有什么區別。

    我們首先用第一種方式寫一個線程類:
    代碼如下:


    package Ticket;


    public class Extends {
     
     public static void main(String[] args){
              //實例化進程并準備執行
              new Thread(new MyThread(),"001窗口").start();
              new Thread(new MyThread(),"001窗口").start();
              new Thread(new MyThread(),"001窗口").start();
     
             }

    }

    class MyThread extends Thread{
             //定義一個變量
              private int ticket = 10;
     
              public void run(){
         
              //這里之所以要循環300次,就是為了讓所有的 車票都賣出去!可能你會想,為什么不是30呢?
              //嘿嘿。。。聰明的你肯定明白這個循環的次數為什么會多出票數很多?=====其實我開始也不知道!!!  ==||| 
            
              for(int i=0;i<300;i++){
                   try {
                        //調用sell()方法
                        this.sell();
                        Thread.sleep(10);
                     } catch (InterruptedException e) {
                                e.printStackTrace();
                     }
      }
     
     }
               public void sell(){
                      if(ticket>0){
                               System.out.println(Thread.currentThread().getName() + " ===> 還剩下" + (ticket--) + "車票");
                      }
     }
    }



    看看這個程序的運行結果你就明白為什么繼承Thread類實現線程類的一個弊端 




    ------------------------------------------------
    大家都發現了吧!輸出的結果和預想的不一樣!!!

    我們來分析一下代碼,查看main函數:
              new Thread(new MyThread(),"001窗口").start();
              new Thread(new MyThread(),"001窗口").start();
              new Thread(new MyThread(),"001窗口").start();

    我們可以看出,實例化了三個MyThread類,這樣的話,private int ticket = 10;就運行了三次,所以ticket打印出來的 也就是30張;在這里注意一下并不是ticket賦值為30,而是ticket賦值為10,但賦值了三次!!!也就是現在有三個ticket!!!
    這樣并不能實現資源共享!
    我們知道我們利用多線程就是為了將多個線程去處理一個數據的集合!!! 他們是同時處理的!!!如果向上面的話,并沒有將數據的集合(ticket)進行共享,而是將每一個類都從新建了一個數據的集合,分別對自己的集合進行處理!!!!
    如果想解決這個問題,其實也很簡單,不過如果當數據的類型和種類比較多的時候,這樣寫就太麻煩了!!!!

    那實現Runnable接口的線程類可不可以呢!!???

    下面來看一看:

    代碼如下:


    package IO;

    public class Inter {

        public static void main(String[] args){
            //聲明并實例化一個MyThread01類
            MyThread01 mt = new MyThread01();
            new Thread(mt,"001窗口").start();
            new Thread(mt,"002窗口").start();
            new Thread(mt,"003窗口").start();

        }
       
    }

    class MyThread01 implements Runnable{
       
        private int ticket = 10;   
        public void run(){   
            for(int i=0;i<200;i++){
                try {
                    this.sell();
                    Thread.sleep(10);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
           
        }
        public void sell(){
            if(ticket>0){
                System.out.println(Thread.currentThread().getName() + " ===> 還剩下" + (ticket--) + "車票");
            }
           
        } 
    }
           

    ---------------------------------------------
    這段程序的運行結果:


    看看這個結果是不是和自己想的一樣啊!!!這樣就可以了!!!用這個方法去創建一個線程類是不是可以達到資源共享啊!!!
    其實啊!我看來,所謂的資源共享也就是將一個數據的集合讓多個線程去處理!!!
    我們看一下代碼!!!
            MyThread01 mt = new MyThread01();
            new Thread(mt,"001窗口").start();
            new Thread(mt,"002窗口").start();
            new Thread(mt,"003窗口").start();

    我們可以看出這個過程中,我們只聲明并實例化了一個MyThread01類,也就是說在這里過程中,給ticket進行了初始化!!!
    但大家要注意的是:真正創建處理數據的線程是
            new Thread(mt,"001窗口").start();
            new Thread(mt,"002窗口").start();
            new Thread(mt,"003窗口").start();
    因此,這樣可以將一個ticket的數據集 由三個線程來處理!!!
    這樣就是所謂的資源共享!!!
    ok???



    =====================================================================


    總結一下這兩種方式的特點:

    1.繼承Thread來創建線程類的方法,在繼承了Thread后,不能再繼承其他類,這樣靈活性就不如實現Runnable接口來創建線程類的方法了!!!
    2.正如上面所說的使用實現Runnable接口來創建線程類的方法可以達到資源共享!!!(在這里說明一下:繼承Thread類來創建線程類的方法也可以實現資源共享,只不過比較麻煩!!!因此,在創建線程類的時候,應優先選擇實現Runnable接口來創建線程類的方法!!!)







    posted on 2010-11-07 20:30 tovep 閱讀(5969) 評論(8)  編輯  收藏

    FeedBack:
    # re: Java_線程類兩種創建方式的區別[未登錄] 2010-11-07 22:15 feenn
    ............
    第一種實現方法中,每一個thread都傳入了一個new MyThread(),那是三個實例啊,能和runnable的實現一樣的么,能實現共享才怪了。。。。  回復  更多評論
      
    # re: Java_線程類兩種創建方式的區別 2010-11-07 23:14 Tovep
    @feenn
    其實實現有很多方法啊!
    你可以把ticket設置為static就可以了!!!  回復  更多評論
      
    # re: Java_線程類兩種創建方式的區別[未登錄] 2010-11-08 08:45 feenn
    @Tovep
    是可以有很多方法,但是你文中的這種比較方法明顯是有問題的。繼承Thread的方法在實例化的時候使用了三個實例,而在實現Runnable的時候實例化只使用了一個實例,因此這兩種實驗是不具備可比性的,因此結論也無從說起。  回復  更多評論
      
    # re: Java_線程類兩種創建方式的區別[未登錄] 2010-11-08 08:54 feenn
    @Tovep
    因此針對于你的文章,結論1是正確的,但是文章的例子和整個推導過程并不能體現這個結論。
    對于結論2,個人不敢茍同,是否方便實現共享是設計的問題,而不是某個類或接口天生具有的屬性。因此,能方便的實現資源共享并不是我們在設計的時候優先選擇runnable的理由。  回復  更多評論
      
    # re: Java_線程類兩種創建方式的區別 2010-11-08 17:27 weyling
    恩,你懂的@feenn
      回復  更多評論
      
    # re: Java_線程類兩種創建方式的區別 2010-11-17 09:49 icejoywoo
    你第一個例子程序中每次運行開始都new了一個線程, 如果和第二個例子一樣, 只寫一個new, 然后start三次的話, 結果是一樣的, 只是線程的執行順序是隨機的  回復  更多評論
      
    # re: Java_線程類兩種創建方式的區別[未登錄] 2014-12-23 09:54 dd
    SB  回復  更多評論
      
    # re: Java_線程類兩種創建方式的區別 2015-05-22 10:57 www
    用個靜態變量就ok了,還要搞得這么麻煩  回復  更多評論
      

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


    網站導航:
     
    主頁 主站蜘蛛池模板: 日韩成人精品日本亚洲| 无码人妻一区二区三区免费n鬼沢| 真人做人试看60分钟免费视频 | 久久久久久噜噜精品免费直播| 四虎成人免费网站在线| 中文字幕不卡亚洲 | 亚洲 欧洲 视频 伦小说| 永久免费视频网站在线观看| 911精品国产亚洲日本美国韩国| A国产一区二区免费入口| 亚洲日韩av无码| 青青草原1769久久免费播放| 亚洲gv白嫩小受在线观看| 亚洲精品天堂无码中文字幕| 精品剧情v国产在免费线观看| 久久久久亚洲精品美女| 久久国产精品免费网站| 久久国产亚洲高清观看| 欧洲黑大粗无码免费| 亚洲人成无码网站| 国产精品亚洲аv无码播放| 免费v片视频在线观看视频| 亚洲精品美女久久久久99| 国产va免费精品| 免费看韩国黄a片在线观看| 亚洲小说图区综合在线| 国产一级做a爱免费视频| 岛国岛国免费V片在线观看| 国产又长又粗又爽免费视频| 亚洲白色白色永久观看| 国产精品免费AV片在线观看| 亚洲国产美女视频| 国产一级特黄高清免费大片| 日本高清不卡aⅴ免费网站| 亚洲午夜成人精品电影在线观看 | 亚洲AV无码国产精品色| 一级毛片**不卡免费播| 亚洲字幕AV一区二区三区四区 | 99久久99这里只有免费的精品| 午夜影视日本亚洲欧洲精品一区| 国产va免费精品观看精品|