国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Java并發(fā)(Runnable+Thread)實(shí)現(xiàn)硬盤(pán)文件搜索功能

瀏覽:3日期:2022-08-17 16:41:47
零、插播2020CSDN博客之星投票新聞

近日(1月11日-1月24日),2020CSDN博客之星評(píng)選正在火熱進(jìn)行中,作為碼齡1年的小白有幸入選Top 200,首先很感謝CSDN官方把我選上,本來(lái)以為只是來(lái)湊熱鬧,看大佬們PK 。

綜合過(guò)去9天大佬們戰(zhàn)況,前10名大佬基本坐得很穩(wěn),后期出現(xiàn)黑馬發(fā)力,勢(shì)不可擋,都在沖刺Top 20,有了微妙的變化,不得不令人佩服點(diǎn)贊!真正的實(shí)力可以看出,文章數(shù)量不重要,更重要的是質(zhì)量!一切用數(shù)據(jù)說(shuō)話,如圖:

截至 2021-01-20 11:50:02

Java并發(fā)(Runnable+Thread)實(shí)現(xiàn)硬盤(pán)文件搜索功能

看了大佬的驚人數(shù)據(jù),與我差距甚大,不禁感慨,接下來(lái)看看我自己!

首先,很感謝每一位幫忙投票的粉絲和兄弟姐妹們,感謝您的關(guān)注和支持,經(jīng)過(guò)大家上一周的共同努力,我已進(jìn)入2020博客之星投票排行榜Top 100。

投票還有一周時(shí)間,進(jìn)入更激烈更有懸念的階段,希望讀者們下來(lái)一周能投出您手中寶貴的票權(quán),讓我更進(jìn)一步!

投票地址:https://bss.csdn.net/m/topic/blog_star2020/detail?username=charzous

或者掃碼投票:

Java并發(fā)(Runnable+Thread)實(shí)現(xiàn)硬盤(pán)文件搜索功能

Java并發(fā)(Runnable+Thread)實(shí)現(xiàn)硬盤(pán)文件搜索功能

重點(diǎn):每一個(gè)投票都會(huì)被記錄,投了之后找Charzous幫忙也容易了(瘋狂暗示投票拉票)!

比如,幫忙下載資源,或者博客一鍵三連,再次對(duì)每位幫我投票的粉絲表示感謝! 😊新的一年,讓我們一起變得更強(qiáng)!

即日起到24號(hào),每天都可以投票哦,票數(shù)越多,貢獻(xiàn)排行榜就越靠前,我就記住你的名字啦!

24號(hào)是否能和大佬們?cè)陧敺逑嘁?jiàn),就靠大家了哈!

一、承上啟下

前一篇學(xué)習(xí)了Java并發(fā)程序設(shè)計(jì)原理之后,為了對(duì)這個(gè)部分有了更深層的理解,并運(yùn)用于實(shí)際場(chǎng)景中,所以我找了比較實(shí)際的案例進(jìn)行實(shí)踐——文件搜索,簡(jiǎn)單來(lái)說(shuō),這也是電腦文件系統(tǒng)中的一個(gè)常見(jiàn)功能,用戶可以通過(guò)用戶名搜索文件系統(tǒng)中符合條件的文件。

文件搜索的程序需要用到Java并發(fā)API中的Thread類和Runnable接口,其中一些重要的內(nèi)容先簡(jiǎn)單了解一下。

二、Java中的多線程

線程類Thread,有兩種方式創(chuàng)建執(zhí)行線程。

1、擴(kuò)展Thread類并重載run()方法

Thread類包含了豐富的方法,在實(shí)現(xiàn)線程時(shí)候必須重載run方法,擴(kuò)展Thread類和調(diào)用start方法創(chuàng)建新的線程。其他常用方法:

getId():獲取Thread對(duì)象的標(biāo)識(shí)符,線程整個(gè)生命周期中唯一不變的一個(gè)正整數(shù)。getName()/setName():String類型,獲取或設(shè)置Thread對(duì)象名。getPriority()/setPriority():獲取或設(shè)置線程的優(yōu)先級(jí)。值范圍:Thread.MIN_PRIORITY~Thread.MAX_PRIORITY(1~10),創(chuàng)建時(shí)默認(rèn)Thread.NORM_PRIORITY(5)。getState():線程對(duì)象的狀態(tài)。包括:NEW(新創(chuàng)建)、RUNNABLE(運(yùn)行中)、BLOCKED(等待鎖定)、WAITING(等待)、TIME_WAITING(有時(shí)間限制等待)、THREAD(完成)。線程在一段時(shí)間中只能處于一種狀態(tài),而且是在JVM中的狀態(tài),不能映射到操作系統(tǒng)的線程狀態(tài)。interrupt():請(qǐng)求結(jié)束執(zhí)行Thread對(duì)象。interrupted():檢查中斷狀態(tài),清除中斷標(biāo)志的值。isInterrupted():檢查中斷狀態(tài),不清除中斷標(biāo)志的值。sleep():線程執(zhí)行睡眠時(shí)間,單位毫秒。join():暫停調(diào)用線程的執(zhí)行,直到調(diào)用該方法的線程執(zhí)行結(jié)束為止。currentThread():靜態(tài)方法,返回實(shí)際執(zhí)行當(dāng)前任務(wù)的Thread對(duì)象。2、實(shí)現(xiàn)Runnable接口

可以通過(guò)線程來(lái)執(zhí)行Runnable對(duì)象,更靈活更改并發(fā)程序,還可以通過(guò)不同線程使用同一個(gè)Runnable對(duì)象。

相對(duì)來(lái)說(shuō),使用Runnable接口創(chuàng)建線程的方法更加推薦,它只定義了run方法,是每個(gè)線程的主方法。當(dāng)執(zhí)行start方法啟動(dòng)新線程時(shí),就會(huì)調(diào)用run方法。

三、串行文件搜索

這里分為兩種版本,串行(單線程)和并發(fā)(多線程),后續(xù)可以進(jìn)行比較。

1、創(chuàng)建公共類Result保存搜索結(jié)果

/** * Result.java * @author Charzous * @date 2021/1/20 11:00 * */ package SearchFiles; public class Result { boolean found; String path; public void setFound(boolean found){ this.found=found; } public boolean isFound(){ return this.found; } public void setPath(String path){ this.path=path; } public String getPath(){ return this.path; }}2、查找算法

算法思路簡(jiǎn)單,通過(guò)初始路徑,獲取文件和目錄內(nèi)容,并與目標(biāo)文件名進(jìn)行比較,相同則記錄Result,算法完成;不同則遞歸遍歷文件,直到算法完成。

/** * * SerialSearch.java * @author Charzous * @date 2021/1/20 11:15 * */ package SearchFiles; import java.io.File; public class SerialFileSearch { public static void searchFiles(File file,String fileName,Result result){ File[] contents; contents=file.listFiles(); if ((contents==null)||(contents.length==0)) return; for (File content:contents){ if (content.isDirectory()) searchFiles(content,fileName,result); else{ if (content.getName().equals(fileName)){ result.setPath(content.getAbsolutePath()); result.setFound(true); System.out.println('Serial Search Path: '+result.getPath()); return; } } if (result.isFound()) return; } } public static void main(String[] args) { Result result=new Result(); File file=new File('D:'); long startTime=System.currentTimeMillis(); String fileName='maskOrder.txt'; SerialFileSearch.searchFiles(file,fileName,result); if (!result.isFound()) System.out.println('未找到該文件:'+fileName); else System.out.println('找到該文件:'+fileName+'!'); System.out.println('查詢時(shí)間:'+(System.currentTimeMillis()-startTime)+'ms'); }}四、并行文件搜索(多線程)1、創(chuàng)建ParallelGroupFileTask類

它實(shí)現(xiàn)所有用于查找文件的線程,實(shí)現(xiàn)Runnable接口,重載run方法,其中包括了處理目錄的processDirectory方法,處理文件的processFile方法。

/** * ParallelGroupFileTask.java * @author Charzous * @date 2021/1/20 11:31 * */package SearchFiles; import java.io.File;import java.util.concurrent.ConcurrentLinkedQueue; class ParallelGroupFileTask implements Runnable { private final String fileName; private final ConcurrentLinkedQueue<File> directories; private final Result parallelResult; private boolean found; public ParallelGroupFileTask(String fileName, ConcurrentLinkedQueue<File> directories, Result parallelResult) { this.fileName = fileName; this.directories = directories; this.parallelResult = parallelResult; } @Override public void run() { while (directories.size() > 0) { File file = directories.poll(); try { processDirectory(file,fileName,parallelResult);//遞歸 if (found) { System.out.println(Thread.currentThread().getName() + ' has found the file'); System.out.println('parallel search:Path :' + parallelResult.getPath()); return; } } catch (Exception e) { System.out.println(Thread.currentThread().getName() + ' hae been interrupted'); } } } public void processDirectory(File file, String fileName, Result parallelResult) throws InterruptedException { File[] contents; contents = file.listFiles(); if ((contents == null) || (contents.length == 0)) return; for (File content : contents) { if (content.isDirectory()) { processDirectory(content, fileName, parallelResult); if (Thread.currentThread().isInterrupted()) throw new InterruptedException(); if (found) return; } else { processFile(content, fileName, parallelResult);//遞歸 if (Thread.currentThread().isInterrupted()) throw new InterruptedException(); if (found) return; } } } public void processFile(File content, String fileName, Result parallelResult) { if (content.getName().equals(fileName)) { parallelResult.setPath(content.getAbsolutePath()); this.found = true; } } public boolean getFound() { return found; } }2、多線程算法

創(chuàng)建ParallelGroupFileSearch類,其中包括了存放基本路徑的線程安全的列表ConcurrentLinkedQueue,然后創(chuàng)建新線程,數(shù)量有JVM中可用的線程數(shù)量,通過(guò)Runtime的availableProcessors方法獲得。

其中,若某個(gè)線程找到目標(biāo)文件,會(huì)使用interrupt方法取消其他線程的執(zhí)行。具體實(shí)現(xiàn)代碼如下:

/** * ParallelGroupFileSearch.java * @author Charzous * @date 2021/1/20 11:40 * */package SearchFiles; import java.io.File;import java.util.concurrent.ConcurrentLinkedQueue; public class ParallelGroupFileSearch { public static void searchFiles(File file, String fileName, Result parallelResult) { ConcurrentLinkedQueue<File> directories = new ConcurrentLinkedQueue<>(); File[] contents = file.listFiles(); for (File content : contents) { if (content.isDirectory()) directories.add(content); } int numThreads = Runtime.getRuntime().availableProcessors(); Thread[] threads = new Thread[numThreads]; ParallelGroupFileTask[] tasks = new ParallelGroupFileTask[numThreads]; for (int i = 0; i < numThreads; i++) { tasks[i] = new ParallelGroupFileTask(fileName, directories, parallelResult); threads[i] = new Thread(tasks[i]); threads[i].start(); } boolean finish = false; int numFinished = 0; while (!finish) { numFinished = 0; for (int i = 0; i < threads.length; i++) { if (threads[i].getState() == Thread.State.TERMINATED) { numFinished++; if (tasks[i].getFound()) finish = true; } } if (numFinished == threads.length) finish = true; } if (numFinished != threads.length) { for (Thread thread : threads) thread.interrupt(); } } public static void main(String[] args) { Result result=new Result(); File file=new File('D:'); String fileName='maskOrder.txt'; long startTime=System.currentTimeMillis(); ParallelGroupFileSearch.searchFiles(file,fileName,result); System.out.println('查詢時(shí)間:'+(System.currentTimeMillis()-startTime)+'ms'); } }五、結(jié)果1、串行(單線程)

串行版本多次測(cè)試結(jié)果用時(shí)在1900ms左右!

10次測(cè)試數(shù)據(jù):

查詢時(shí)間:1978ms 2036 1860 1926 1861 2100 1889 2030 1905 1990

Java并發(fā)(Runnable+Thread)實(shí)現(xiàn)硬盤(pán)文件搜索功能

Java并發(fā)(Runnable+Thread)實(shí)現(xiàn)硬盤(pán)文件搜索功能

2、并發(fā)(多線程)

并發(fā)版本多線程測(cè)試用時(shí)在1400ms左右!

10次測(cè)試數(shù)據(jù):

查詢時(shí)間:1441ms 1368 1258 1546 1444 1430 1490 1432 1338 1435

Java并發(fā)(Runnable+Thread)實(shí)現(xiàn)硬盤(pán)文件搜索功能

Java并發(fā)(Runnable+Thread)實(shí)現(xiàn)硬盤(pán)文件搜索功能

從簡(jiǎn)單的測(cè)試結(jié)果可以看出,并發(fā)搜索的算法速度提升明顯。

這一篇通過(guò)實(shí)際的案例進(jìn)行實(shí)踐——文件搜索,簡(jiǎn)單來(lái)說(shuō),這也是電腦文件系統(tǒng)中的一個(gè)常見(jiàn)功能,用戶可以通過(guò)用戶名搜索文件系統(tǒng)中符合條件的文件。Runnable接口和Thread類的基本使用也有了更深的認(rèn)識(shí)。在文件搜索這個(gè)案例中,學(xué)習(xí)了Java并發(fā)原理的實(shí)際應(yīng)用,首先設(shè)計(jì)一種串行的版本,然后再實(shí)現(xiàn)并發(fā)的版本,這也是一個(gè)改進(jìn)的過(guò)程。

到此這篇關(guān)于Java并發(fā)(Runnable+Thread)實(shí)現(xiàn)硬盤(pán)文件搜索的文章就介紹到這了,更多相關(guān)Java并發(fā)硬盤(pán)文件搜索內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 亚洲综合网在线 | 香港全黄一级毛片在线播放 | 男女福利社 | 国产一级小视频 | 日韩免费黄色片 | 亚洲精品国产字幕久久不卡 | 亚洲黄a| 久久无码精品一区二区三区 | 欧美一级做一级爱a做片性 欧美一欧美一级毛片 | 久久久免费观成人影院 | 国产农村一二三区 | 久久免费国产视频 | 精品国产97在线观看 | 国产伦码精品一区二区三区 | 2020精品极品国产色在线观看 | 一级毛片一级毛片一级毛片 | 久操视频免费在线观看 | 国产精品亚洲精品不卡 | 在线播放精品一区二区啪视频 | 日本不卡一区二区三区在线观看 | 综合久久99久久99播放 | 中文国产成人精品久久一 | 毛片随便看 | 韩国视频一区 | 久久精品国产一区二区三区不卡 | 毛片基地免费视频a | 国产精品成人观看视频网站 | 免费一级毛片在线观看 | 国内精品1区1区3区4区 | 国产第2页| 成人午夜视频免费观看 | 欧美亚洲精品在线 | 91精品国产色综合久久 | 理论视频在线观看 | 欧美日韩国产高清一区二区三区 | 草草影院ccyy国产日本欧美 | 久久免费视频1 | 91人碰| 69视频成人 | 精品国产91久久久久久久a | 国产精品三级国语在线看 |