如何在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()是一个更好的选择) 如果您拥有只能杀死的库,则需要在单独的进程中运行它并杀死整个过程。这将确保操作系统清除所有使用的资源。 (假设它没有留下临时文件等;)     

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...