Java中怎么搜索阻塞队列

本篇文章为大家展示了Java中怎么搜索阻塞队列,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

目前创新互联已为千余家的企业提供了网站建设、域名、雅安服务器托管、网站托管、服务器托管、企业网站设计、青河网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。

Java阻塞队列怎么搜索

java.util.concurrent包提供了阻塞队列的4个变种:LinkedBlockingQueue、ArrayBlockingQueue、PriorityBlockingQueue和DelayQueue。我们用的是ArrayBlockingQueue。ArrayBlockingQueue在构造时需要给定容量,并可以选择是否需要公平性。如果公平参数被设置了,等待时间最长的线程会优先得到处理。通常,公平性会使你在性能上付出代价,只有在的确非常需要的时候再使用它。

生产者线程枚举在所有子目录下的所有文件并把它们放到一个阻塞队列中。这个操作很快,如果队列没有设上限的话,很快它就包含了没有找到的文件。

我们同时还启动了大量的搜索线程。每个搜索线程从队列中取出一个文件,打开它,打印出包含关键字的所有行,然后取出下一个文件。我们使用了一个小技巧来在工作结束后终止线程。为了发出完成信号,枚举线程把一个虚拟对象放入队列。(这类似于在行李输送带上放一个写着“最后一个包”的虚拟包。)当搜索线程取到这个虚拟对象时,就将其放回并终止。

注意,这里不需要人任何显示的线程同步。在这个程序中,我们使用队列数据结构作为一种同步机制。

Java阻塞队列怎么搜索

importjava.io.*;

importjava.util.*;

importjava.util.concurrent.*;

publicclassBlockingQueueTest

{

publicstaticvoidmain(String[]args)

{

Scannerin=newScanner(System.in);

System.out.print("Enterbasedirectory(e.g./usr/local/jdk1.6.0/src):");

Stringdirectory=in.nextLine();

System.out.print("Enterkeyword(e.g.volatile):");

Stringkeyword=in.nextLine();

finalintFILE_QUEUE_SIZE=10;

finalintSEARCH_THREADS=100;

BlockingQueuequeue=newArrayBlockingQueue(FILE_QUEUE_SIZE);

FileEnumerationTaskenumerator=newFileEnumerationTask(queue,newFile(directory));

newThread(enumerator).start();

for(inti=1;i<=SEARCH_THREADS;i++)   newThread(newSearchTask(queue,keyword)).start();   }   }   /**   *Thistaskenumeratesallfilesinadirectoryanditssubdirectories.   */   classFileEnumerationTaskimplementsRunnable   {   /**   *ConstructsaFileEnumerationTask.   *@paramqueuetheblockingqueuetowhichtheenumeratedfilesareadded   *@paramstartingDirectorythedirectoryinwhichtostarttheenumeration   */   publicFileEnumerationTask(BlockingQueuequeue,FilestartingDirectory)

{

this.queue=queue;

this.startingDirectory=startingDirectory;

}

publicvoidrun()

{

try

{

enumerate(startingDirectory);

queue.put(DUMMY);

}

catch(InterruptedExceptione)

{

}

}

/**

*Recursivelyenumeratesallfilesinagivendirectoryanditssubdirectories

*@paramdirectorythedirectoryinwhichtostart

*/

publicvoidenumerate(Filedirectory)throwsInterruptedException

{

File[]files=directory.listFiles();

for(Filefile:files)

{

if(file.isDirectory())enumerate(file);

elsequeue.put(file);

}

}

publicstaticFileDUMMY=newFile("");

privateBlockingQueuequeue;

privateFilestartingDirectory;

}

/**

*Thistasksearchesfilesforagivenkeyword.

*/

classSearchTaskimplementsRunnable

{

/**

*ConstructsaSearchTask.

*@paramqueuethequeuefromwhichtotakefiles

*@paramkeywordthekeywordtolookfor

*/

publicSearchTask(BlockingQueuequeue,Stringkeyword)

{

this.queue=queue;

this.keyword=keyword;

}

publicvoidrun()

{

try

{

booleandone=false;

while(!done)

{

Filefile=queue.take();

if(file==FileEnumerationTask.DUMMY)

{

queue.put(file);

done=true;

}

elsesearch(file);

}

}

catch(IOExceptione)

{

e.printStackTrace();

}

catch(InterruptedExceptione)

{

}

}

/**

*Searchesafileforagivenkeywordandprintsallmatchinglines.

*@paramfilethefiletosearch

*/

publicvoidsearch(Filefile)throwsIOException

{

Scannerin=newScanner(newFileInputStream(file));

intlineNumber=0;

while(in.hasNextLine())

{

lineNumber++;

Stringline=in.nextLine().trim();

if(line.contains(keyword))System.out.printf("%s:%d%s%n",file.getPath(),lineNumber,line);

}

in.close();

}

privateBlockingQueuequeue;

privateStringkeyword;

}

上述内容就是Java中怎么搜索阻塞队列,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注创新互联行业资讯频道。


本文题目:Java中怎么搜索阻塞队列
分享链接:http://scyanting.com/article/gsidgh.html