草庐IT

thread-confinement

全部标签

java - "Thread.currentThread().getName"和 "this.getName"有什么区别?

这是代码:importjava.util.concurrent.ExecutorService;importjava.util.concurrent.Executors;importjava.util.concurrent.ThreadFactory;classUnCatchExceptionThreadextendsThread{publicUnCatchExceptionThread(Stringname){this.setName(name);}@Overridepublicvoidrun(){System.out.println("Threadnameis:"+this.get

java - 如何理解Java Thread中的wait和notify方法?

我对这两个描述感到很困惑:“等待方法阻塞调用线程并放弃监视器锁”“notify方法解除了一个等待线程的阻塞,但没有放弃监视器锁”这是我的问题:我知道Java中的每个对象都有一个锁,但是“监控锁”是什么意思呢?它和对象的锁一样吗?为什么notify方法需要放弃监听锁?如果我尝试使用以下代码让对象等待:classsimpleTaskextendsThread{intwaitingTime;publicsimpleTask(intwaitingTime){this.waitingTime=waitingTime;}publicvoidrun(){synchronized(this)//thi

java - 理解 Thread.currentThread().getContextClassLoader().getResourceAsStream()

我正在查看代码示例,但不确定这意味着什么。Thread.currentThread().getContextClassLoader().getResourceAsStream("MyProperty.properties");它似乎想要读取属性文件,但我不确定MyProperty.properties的位置。感谢您的帮助,谢谢。 最佳答案 ItappearsthatitlookingtoreadapropertyfilebutIamnotsurewhereMyProperty.propertiesislocated.正如您当前拥有的

java - 在 Callable 中处理 Thread.interrupted() 的正确方法?

在Callable中处理Thread.interrupted()的正确方法是什么?我猜可调用对象应该抛出一个InterruptedException;例如:publicclassMyCallableimplementsCallable{publicObjectcall(){Objectresult=null;//Simulatelong-runningoperationthatcalculatesresultwhile(true){...if(Thread.interrupted()){thrownewInterruptedException();}}result=...//somet

java - Java : what's the point? 中的 Thread.interrupt()

这个问题在这里已经有了答案:JavalongrunningtaskThreadinterruptvscancelflag(5个答案)关闭9年前。我完全理解它的作用(至少我希望如此)。它并没有真正中断线程。它使Thread.isInterrupted()为真,代码应该检查是什么方法并停止线程本身。我的问题是,为什么我们甚至需要这种方法?它似乎完全可以通过声明一个boolean标志来说明是否应该停止这个线程来替换?没有任何Java教科书使用这个boolean标志作为应如何使用volatile关键字的最佳示例吗?我特别困惑,因为似乎没有办法“不中断”线程,因为Thread.resume()已

java.lang.Thread - threadStatus 从何而来?

通过Javasourcecode我们有那个//variablenotwrittenorupdatedanywhereonthisclassprivatevolatileintthreadStatus=0;publicStategetState(){//getcurrentthreadstatereturnsun.misc.VM.toThreadState(threadStatus);}threadStatus如何以及在哪里更新?我们的想法是最终尝试使用AOP围绕更新方法进行编织,并在threadStatus更改时进行回调。 最佳答案

java - java线程间通信: stopping all threads when one finishes its task

我有n个线程并行运行,每个线程都执行一些自定义逻辑。但是,我的要求是,当任何一个线程完成执行时,所有其他线程都应该停止执行并返回。实现它的最佳方法是什么?我想通过共享boolean变量来做到这一点。当任何线程完成执行时,它将设置boolean值。所有线程都定期读取此变量并在设置时退出。此外,我的自定义逻辑是一个无限循环,一旦我知道某个其他线程已完成执行,我想在当前迭代后停止执行。这样做的正确方法是什么? 最佳答案 使用ExecutorService及其.invokeAny()方法(注:也有超时的版本)。来自Javadoc:Execu

java - 替代 Thread.suspend() 和 .resume()

我有一大段代码不是循环,只是执行一次但需要一些时间的命令列表。我需要它根据不断变化的boolean值随时暂停或终止它。我可以使用不同的线程来挂起、恢复和停止此代码,但这些方法已被弃用,因此我想避免使用它们。我可以检查每一行代码之间的boolean值,但我希望有一个更优雅的解决方案。有什么好的方法吗? 最佳答案 Icouldcheckthebooleanbetweeneverylineofcode,butIamhopingforamoreelegantsolution.Isthereagoodwaytodothis?很遗憾,没有。要替

java - GWT、Google App Engine、TimerTask 或 ServiceImpl 中的 Thread 抛出异常

我正在使用GWT和GoogleAppEngine。我有一系列记录,我想每30分钟更新一次。在ServiceImpl中,我有以下代码:newTimer().schedule(newTimerTask(){@Overridepublicvoidrun(){try{Thread.sleep(30000);}catch(InterruptedExceptione){e.printStackTrace();}result=updateFeeds();}},30000,Long.MAX_VALUE);当我运行应用程序时,当我得到:com.google.gwt.user.server.rpc.Une

java - 多 :Threading - Is this the right approach?

专家-在以下情况下我需要一些建议。我有一个包含任务列表的配置文件。每个任务可以有零个、一个或多个依赖项。我想并行执行这些任务[现在它们正在按顺序执行]想法是有一个主程序来读取配置文件并加载所有任务。读取单个任务并将其交给将执行任务并在Future中返回结果的执行程序[callable]。当任务被提交给执行者(线程)时,它将监视其依赖项是否首先完成并执行自己的任务。这是正确的方法吗?使用Java1.5功能还有其他更好的方法吗? 最佳答案 听起来不错,但要注意线程饥饿死锁。基本上,不要使用有界线程池。这里有一个例子可以说明这个问题。ht