草庐IT

thread_blocked

全部标签

java - Thread.holdsLock(lock) 的目的是什么?

我看到有人用断言!Thread.holdsLock(lock)以避免死锁。这样做的目的是什么?如果锁对象被另一个线程持有,assert会导致代码立即退出吗? 最佳答案 javadocofthemethod说:Returnstrueifandonlyifthecurrentthreadholdsthemonitorlockonthespecifiedobject.(强调我的)因此,断言检查当前线程是否持有给定锁对象的监视器锁。请注意,断言用于检查不变量,可以禁用。它们不应用于防止死锁。应该使用常规的if测试来做到这一点。

java - Thread 类的 join() 方法是如何工作的?

考虑以下代码:classThreadJoinTest{publicstaticvoidmain(String[]arguments){TimeUnitunit;finalThreadtaskThread=newThread(task);taskThread.start();taskThread.join(unit.millis(timeout));}}因此,当主线程执行带有超时值的taskThread.join()行时,主线程会为taskThread提供充足的时间来完成其任务?这是join方法的主要目标吗?如果发生什么情况:taskThread在超时期限之前完成它的执行?如果达到超时但

java - 如何在 Java 6 中捕获所有已检查的异常(在一个 block 中)?

重要提示:此问题仅与Java6(及更低版本)有关。层次结构here显示JavaException分为两种类型:RuntimeException和[notaRuntimeException]:将它分成类似UncheckedException和CheckedException这样的东西不是更好吗?例如,下面的语句有相当多的已检查异常:try{transaction.commit();}catch(SecurityExceptione){}catch(IllegalStateExceptione){}catch(RollbackExceptione){}catch(HeuristicMixe

java - 初始化 block 可以抛出异常吗?

我在类中使用BufferedReader来读取文件。我试图在初始化block中初始化它。classReadFromFile{BufferedReaderbr;{br=newBufferedReader(newFileReader(newFile("file.txt")));}}初始化block中的行抛出FileNotFoundException异常。所以,编译器给出错误。我不想用try-catchblock包围它。我通过使用构造函数而不是初始化block解决了这个问题,比如:classReadFromFile{BufferedReaderbr;publicReadFromFile()t

java - 没有任何 catch 语句的 Try block

我正在通读一本Java教科书中有关异常和断言的一章,并遇到了我有疑问的这段代码。publicbooleansearchFor(Stringfile,Stringword)throwsStreamException{Streaminput=null;try{input=newStream(file);while(!input.eof())if(input.next().equals(word))returntrue;returnfalse;//notfound}finally{if(input!=null)input.close();}}在下一段中,文本说“searchFor方法声明它抛

java - 有没有办法多次执行静态 block ?如果是这样,那又如何呢?

我的理解静态block在类加载期间执行,如果类已经加载则除了类重新加载之外没有办法加载该类疑问/问题1)JVM是否有重新加载类的时间?我的理解在类加载中,JVM加载Java文件的字节码,因此它无法将所有数千个类的字节码保存在内存中,因此它可能会丢弃很少使用的代码并在必要时重新加载它,并且在重新加载期间JVM不会初始化静态变量和再次阻塞(可能使用了一些跟踪机制)疑问/问题2)如果我上面的理解不正确,请指正 最佳答案 据我所知,JVM本身永远不会重新加载一个类;一旦加载了一个类,它就会永远保持加载状态。出于这个原因,类定义保存在“Per

java - Spring MVC : What happens if I start a thread in a controller action?

在SpringMVCController中,我想启动一个线程,该线程在我的Controller发送响应时继续工作。这可以与spring-mvc一起使用吗?最佳记录,海因里希 最佳答案 是的,您可以在Controller中启动新线程。但是执行异步工作的更好方法是使用spring-scheduling支持。您可以利用Quartz框架。那将管理你的工作。这link将为您介绍如何将其集成到您的应用程序中。 关于java-SpringMVC:WhathappensifIstartathreadin

java - Threads之间划分一个奇数

我正在学习Java中的线程,我想按字母顺序对单词列表进行排序。我的程序读取一个txt文件的单词并将它们放入一个字符串数组中。用户可以自己选择要使用多少个线程。我想将数组拆分为线程可以自行排序的均匀(尽可能)block。所以我的问题是:如何在线程间尽可能均匀地拆分array.length?我的大脑一片空白,我想不出一个聪明的方法来做到这一点。例如:如果我有一个array.length为22和4个线程,在这种情况下如何给线程;6、6、5和5大小的数组?需要适用于给定的每个数字。我尽量解释清楚了,有什么不明白的地方请追问!谢谢! 最佳答案

java - 为什么 Thread 类中的 setName 分配给字符数组?为什么不是字符串?

当我处理Java中的线程概念时,我看到了Thread.java源文件。我注意到setName()方法将字符串分配给名为"name[]"的字符数组。Java有一个String数据类型的特性,那么为什么他们使用字符数组。在源文件中,它被初始化为,privatecharname[];//whynot"privateStringname;"在setName()方法中,publicfinalvoidsetName(Stringname){checkAccess();this.name=name.toCharArray();}请帮帮我。提前致谢。 最佳答案

java - 在 Java 中使用 Thread#stop() 来终止一个正在运行的线程是否可以接受?

遗憾的是,在Java中对字符串使用正则表达式时无法指定超时。因此,如果您没有严格控制将哪些模式应用于哪些输入,您最终可能会拥有消耗大量CPU的线程,同时无休止地尝试将(设计不佳的)模式与(恶意的?)输入匹配。我知道Thread#stop()被弃用的原因(参见http://download.oracle.com/javase/1.5.0/docs/guide/misc/threadPrimitiveDeprecation.html)。它们以可能在ThreadDeath异常情况下损坏的对象为中心,然后这些对象会污染您正在运行的JVM环境并可能导致细微的错误。对于比我对JVM的工作原理有更深