本篇文章为大家展示了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;
BlockingQueue
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(BlockingQueue
{
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("");
privateBlockingQueue
privateFilestartingDirectory;
}
/**
*Thistasksearchesfilesforagivenkeyword.
*/
classSearchTaskimplementsRunnable
{
/**
*ConstructsaSearchTask.
*@paramqueuethequeuefromwhichtotakefiles
*@paramkeywordthekeywordtolookfor
*/
publicSearchTask(BlockingQueue
{
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();
}
privateBlockingQueue
privateStringkeyword;
}
上述内容就是Java中怎么搜索阻塞队列,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注亿速云行业资讯频道。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。