Java 多線程之龜兔賽跑(文件夾——讀取文件——時間)

来源:http://www.cnblogs.com/newromantics/archive/2016/01/04/5099860.html
-Advertisement-
Play Games

版權聲明:本文為博主原創文章,未經博主允許不得轉載。描述:烏龜和兔子(各自是一個Java線程)在我們的電腦上賽跑,我們為它們指定一個跑道(本地文件系統上的一個目錄,該目錄包含子目錄)。跑的規則是讀“跑道”上的所有文件。兔子很聰明,只讀文件的元信息(路徑名、大小、最後修改時間),但每讀完一個文件就要睡...


 

 

版權聲明:本文為博主原創文章,未經博主允許不得轉載。

 

描述:

烏龜和兔子(各自是一個Java線程)在我們的電腦上賽跑,我們為它們指定一個跑道(本地文件系統上的一個目錄,該目錄包含子目錄)。跑的規則是讀“跑道”上的所有文件。兔子很聰明,只讀文件的元信息(路徑名、大小、最後修改時間),但每讀完一個文件就要睡1秒鐘;烏龜很笨,讀文件的每一個位元組(烏龜每次讀取數據的大小不超過1024位元組),但是它不停歇地讀,直到讀完所有文件。寫程式模擬它們同時起跑的比賽過程,最後輸出“兔子贏!”或“烏龜贏!”

 

 1 import java.io.File;
 2 
 3 /**兔子線程
 4  *  路徑名 大小 最後修改時間 讀完一個文件sleep。。
 5  * @author gang
 6  *
 7  */
 8 public class Rabbit implements Runnable{
 9     File file;
10     public Rabbit(){
11         file = null;
12     }
13     public Rabbit(File file){
14         this.file = file;
15     }
16     public void run(){
17         read(file);
18     }
19     
20     public void read(File file){
21         if(file.isDirectory()){
22             for(File files:file.listFiles())
23                 read(files);
24         } else {
25             file.getAbsolutePath();
26             file.lastModified();
27             file.length();
28             try {
29                 Thread.sleep(1000);
30             } catch (InterruptedException e) {
31                 // TODO Auto-generated catch block
32                 e.printStackTrace();
33             }
34         }
35     }
36 }
 1 package Thread;
 2 
 3 import java.io.File;
 4 import java.io.FileInputStream;
 5 import java.io.FileNotFoundException;
 6 import java.io.IOException;
 7 
 8 /**烏龜線程
 9  *  每次讀取不超過1024位元組 一直讀完整個文件夾
10  * @author gang
11  *
12  */
13 public class Turtle implements Runnable{
14     File file;
15     public Turtle(){
16         file = null;
17     }
18     public Turtle(File file){
19         this.file=file;
20     }
21     public void run() {
22         // TODO Auto-generated method stub
23         try {
24             read(file);
25         } catch (IOException e) {
26             // TODO Auto-generated catch block
27             e.printStackTrace();
28         }
29     }
30     
31     public void read(File file) throws IOException{
32         if(file.isDirectory()){
33             for(File files:file.listFiles())
34                 read(files);
35         } else{
36             FileInputStream fiStream = new FileInputStream(file);
37             byte b[] = new byte[1024];
38             int i;
39             while((i = fiStream.read(b)) != -1);
40         }
41     }
42 }
 1 package Thread;
 2 
 3 import java.io.File;
 4 import java.util.Scanner;
 5 
 6 /**龜兔線程測試  輸入相應的文件夾  
 7  * 
 8  * @author gang
 9  *
10  */
11 public class MainThread {
12     public static void main(String[] args){
13         String pathStr;           
14         Scanner in = new Scanner(System.in);  
15         pathStr = in.nextLine();            // input pathFile
16         File path = new File(pathStr);     // path
17         
18         Rabbit rabbit = new Rabbit(path);
19         Turtle turtle = new Turtle(path);
20         
21         long t1Begin = System.currentTimeMillis();   //start
22         Thread t1 = new Thread(rabbit);
23         t1.start();
24         while(t1.isAlive());  
25         long t1End = System.currentTimeMillis();   // t1 end
26         
27         long t2Begin = System.currentTimeMillis();   //start
28         Thread t2 = new Thread(turtle);
29         t2.start();
30         while(t2.isAlive());
31         long t2End = System.currentTimeMillis();   // t2 end
32         
33         // 測試結果
34         if((t1End-t1Begin) > (t2End-t2End)){
35             System.out.printf("time of Rabbit is %d ms.\n",(t1End-t1Begin));
36             System.out.printf("time of Turtle is %d ms.\n",(t2End-t2Begin));
37             System.out.println("Turtle win the game.");
38         } else if((t1End-t1Begin) < (t2End-t2End)){
39             System.out.printf("time of Rabbit is %d ms.\n",(t1End-t1Begin));
40             System.out.printf("time of Turtle is %d ms.\n",(t2End-t2Begin));
41             System.out.println("Rabbit win the game.");
42         } else{
43             System.out.printf("time of Rabbit is %d ms.\n",(t1End-t1Begin));
44             System.out.printf("time of Turtle is %d ms.\n",(t2End-t2Begin));
45             System.out.println("nobody win the game.");
46         }
47     } 
48 }

 

代碼解釋見上註釋。

輸入相應測試的文件夾,即可開始測試,若文件項目多,則運行時間較長,請耐心等待。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 基於jQuery交互體驗社會化分享代碼。這是一款滑鼠點擊分享按鈕向右滑出騰訊微博,新浪微博,QQ空間,豆瓣,微信,二維碼分享等分享平臺。效果圖如下:線上預覽源碼下載實現的代碼。html代碼: via:http://www.w2bc.com/ar...
  • 1、簡介Node.js REPL(Read Eval Print Loop:互動式解釋器) 表示一個電腦的環境,類似 Window 系統的終端或 Unix/Linux shell,我們可以在終端中輸入命令,並接收系統的響應。Node 自帶了互動式解釋器,可以執行以下任務:讀取- 讀取用戶輸入,解析輸...
  • <h2 CSS 輪廓(Outline)實例</h2 <h3 CSS 實例</h3 CSS 背景實例 CSS 文本實例 CSS 字體(font)實例 CSS 邊框(border)實例 CSS 外邊距 (margin) 實例 CSS 內邊距 (padding) 實例 CSS 列表實例 CSS 表格實例....
  • 對象創建:當虛擬機遇到一條new指令時,首先將檢查這個指令參數能否在常量池中定位到一個類的符號引用,並檢查這個類的符號引用是否被載入、解析和初始化,如果沒有,必須先執行類的載入過程。在類完成載入後,虛擬機便會為類分配記憶體,而記憶體的大小在類載入完成時就已經確定了,若Java堆的記憶體是絕對規整的,即用過...
  • 1.1 Exception in thread "main" org.springframework.beans.factory.BeanDefinitionStoreException: Unexpected exception parsing XML document from class pa...
  • 在OC中結構體有時候也作為對象的屬性類的定義#import typedef struct{ int year; int month; int day;} Date;@interface Student : NSObject{ @public NSString *_nam...
  • 基礎拾遺 序列解包 例: >>>x,y,z=1,2,3 >>>print x,y,z 1 2 3 交換變數也是沒問題 >>>x,y=y,x >>>print x,y,z 2 1 3 #這個很實用 當函數或方法返回元組(或其它序列或可迭代對象)時,這個特性特別有用。假如需要獲取(和刪除)字典中任意的鍵...
  • [新年新氣象,2016/01/04] 俺們在開發IOS程式過程中,經常需要用到NSLog輸出一些信息,甚至有的開發過程,必須在控制台查看輸出,有經驗的程式員通過控制台輸出就能知道整個數據交互的一個流程。但是一個發佈的程式,裡面帶有太多的NSLog輸出,肯定對於App性能有所影響,這時候我們可以...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...