如何解决如何在Java中停止线程并让同一线程做另一件事?
| 我启动一个线程从互联网下载内容,一次,该线程正在下载一个文件,然后我希望它停止并开始下载另一个文件,我该怎么办?我应该依靠Java中的并发机制吗?解决方法
您可以使用单线程执行器启动线程,然后(杀死它)(希望如此)并启动一个新的线程执行器,这将确保它使用同一线程。
// Suppose you have a DownloadFile class that implements Runnable
DownloadFile task1 = new DownloadFile();
...
ExecutorService exec = Executors.newSingleThreadExecutor();
Future<Boolean> future = exec.submit( task1,Boolean.TRUE );
...
// Cancel the task
future.cancel();
// Give the executor another task
DownloadFile task2 = new DownloadFile();
...
exec.submit( task2,Boolean.TRUE );
其他有用的文档:
未来
执行器服务
, 不建议使用stop()
方法停止线程。
我开始一个线程下载
来自互联网的内容,合而为一
时间,线程正在下载一个
文件,然后我希望它停止并
开始下载另一个文件,什么
我该怎么办?
您需要使用Thread
类的sleep()方法为指定的thread3ѭ暂停相同的线程,然后才能继续使用同一线程。
注意:线程停止后,将无法继续工作。这将导致IllegalThreadStateException。
见:
为什么不推荐使用Thread.stop(),Thread.suspend()和Thread.resume()?
如何优雅地停止Java线程?
, 中断当前处理中的线程并将其重定向到其他线程是一个经典的同步问题。这样做如下:
有一个工作队列。作业队列中的作业[或更具体地说,作业队列中的对象]应该具有线程将执行的方法[say process()]。线程通常不知道process()方法的详细信息。它只关心它必须运行process()方法。
线程必须在作业队列上等待。这样做如下:
Job j = null;
synchronized(jobQueueInstance)
{
if(jobQueueInstance.isEmpty())
{
jobQueueInstance.wait();
}
j = jobQueueInstance.poll(); //get the job from the head of the queue
}
try
{
j.process();
}
catch(InterruptedException ex)
{
//thread is interrupted,means it needs to abandon this job and fetch a new one from the queue
}
我希望这有帮助。但是,我省略了一些东西来简化问题:
我已经省略了“ 5”类声明,我想它将是接口还是抽象类。
我也省略了一些其他线程将在jobQueueInstance
上添加new Job()
和notify()
的部分。
还省略了有关该线程的部分,该部分将“ 9”表示“正在运行”的作业运行线程。
注意线程3和4可以是同一线程。
, 您应该使用下载软件在下载上设置超时。这通常会导致异常,您可以捕获该异常,清理正在执行的操作并继续执行。
除非您使用的软件支持中断或超时设置,否则没有安全的方法来强制这种情况在外部发生。如果您打算尽快关闭,则可以安全地使用stop()。 (在这种情况下,System.exit()是一个更好的选择)
如果您拥有只能杀死的库,则需要在单独的进程中运行它并杀死整个过程。这将确保操作系统清除所有使用的资源。 (假设它没有留下临时文件等;)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。