Java线程关闭的3种方法

来源:http://www.guanqinbiaoye.com 作者:计算机编程 人气:152 发布时间:2020-01-31
摘要:Java线程关闭,总的来说有3种:   1.使用状态位,这个简单,就不多说了: 复制代码 代码如下: public class Task extends Thread { 首先,要说的是java中没有一种停止线程的方法是绝对安全的. 线

Java线程关闭,总的来说有3种:

 

1.使用状态位,这个简单,就不多说了:
复制代码 代码如下:
public class Task extends Thread {

首先,要说的是java中没有一种停止线程的方法是绝对安全的.
线程的中断
Thread.interrput()方法很容易给人一种误会,让人感觉是一个线程使另外一个正在运行的线程停止工作,
但实际上interrput仅仅传递了请求中断的信息.线程自己会在下一个方便的时间中断.
某些操作会接受这个请求时发出一个异常,比如wait,sleep.每一个Thread线程都有一个中断状态,是boolean型的当调用interrput方法后会使中断为true.
当使用的静态的interrputed时可以清除中断状态,也就是说连续调用2次interrputed会将中断状态变为false.isInterrupted方法可以返回中断状态.
JDK1.6 API:
interrupted
public static boolean interrupted()Tests whether the current thread has been interrupted. The interrupted status of the thread is cleared by this method. In other words, if this method were to be called twice in succession, the second call would return false (unless the current thread were interrupted again, after the first call had cleared its interrupted status and before the second call had examined it).
A thread interruption ignored because a thread was not alive at the time of the interrupt will be reflected by this method returning false.

private volatile boolean flag= true;

Returns:
true if the current thread has been interrupted; false otherwise.
See Also:

public void stopTask() {

有时候调用interrput方法会出现异常而且中断状态没有改变,你可以在异常处理catch块中使用interrupted=true重试.

flag = false;

Java中断线程的时候分两种情况:第一种是在线程正常执行时,第二种是在线程阻塞时.

}

(1) 正常线程运行时一般会运行一个较长的任务有的会在while(true)中,这种线程最好中断只需要在循环中加入一个if(){break};判断就好.while判断条件是中断状态.嘿.
(2)在线程阻塞的时候进程不会执行其他任何命令,所以不能改变判断状态.这时候使用Thread.interrupt()方法产生一个InterruptedException运行时异常,在catch块中,跑出一个运行时异常(RuntimeException)或使用break;这种方法可以适用于{ Object 类的 wait()、wait(long) 或 wait(long, int) 方法,或者该类的 join()、join(long)、join(long, int)、sleep(long) 或 sleep(long, int) 方法过程中阻塞的线程,能看出来这些方法都会跑出InterruptedException异常}

@Override

 try { 
     TimeUnit.SECONDS.sleep(1); 
 } catch (InterruptedException e) { 
     break; 
     thrownew RuntimeException(); 
 } 

public void run() {

(3)你不可以中断试图获取synchronized锁但是由于锁被占用未被释放而被挂起的线程或者试图执行I/O操作的线程.

while(flag){

a)  对于IO异常

/* do your no-block task */

i.  对于被I/O读写阻塞的线程嘴简单直接的方法是调用基础资源的close()方法.也就是读写的close方法.
(旧IO不会发出InterruptedException异常但是使用close方法会跑出IOException异常同上使用相同方法可以跳出循环中断线程)

}

ii. 在新版本的nio类会自动响应中断,发出IOException异常

}

b) 对于由于互斥堵塞.使用ReentrantLock对象加锁的线程可以被终结,使用ReentrantLock的lockInterruptibly方法,如果当前线程未被中断,则获取锁这就可以中断被互斥的锁。
c)处理反常的线程终止

威尼斯网站,}

在并发程序中,发生异常而未能捕获异常这使得线程执行失败,但是往往这种失败,不会影响程序的继续执行.
导致失败的主要原因还是RuntimeException这种异,通常这种异常是不能捕获的.
如何捕获这些异常呢.
javaAPI提供了这一类问题的解决办法,提供了Thread.UncaughtExceptionHandler(异常处理器具体查看JDK)使你能够检测到线程因未捕获而引起的线程死亡.
可以使用Thread的set方法设置异常处理器.
如果不存在异常处理器则使用System.err输出.
PS:在运行时间较长时间的线程里,为线程提供一个异常处理器是有必要的,至少在这个处理器中记录日志.
为了给线程池中的每个线程都加入异常处理器,可以在建造线程池的时候给定一个ThreadFactory.为每个线程池内的Thread加入异常处理器.
PS.线程池只有通过execute方法才会将异常交给异常处理器.
通过submit方式提交的会使用get方法重新给出异常.
使用异常处理器后不会使用system.err向控制台写入异常.

2.当线程等待某些事件发生而被阻塞,又会发生什么?当然,如果线程被阻塞,它便不能核查共享变量,也就不能停止。这在许多情况下会发生,例如调用 Object.wait()、Thread.sleep等,这里仅举出一些。他们都可能永久的阻塞线程。即使发生超时,在超时期满之前持续等待也是不可行和不适当的,所以,要使用某种机制使得线程更早地退出被阻塞的状态。这个时候你可以使用
复制代码 代码如下:
Thread.interrupt();

public class BlockTask extends Thread {

总的来说有3种:
1.使用状态位,这个简单,就不多说了:

@Override

public class Task extends Thread {
    private volatile boolean flag= true;
   
    public void stopTask() {
        flag = false;
    }
    @Override
    public void run() {
        while(flag){
            /* do your no-block task */
        }
    }
}

public void run() {

2.当线程等待某些事件发生而被阻塞,又会发生什么?
当然,如果线程被阻塞,它便不能核查共享变量,也就不能停止。这在许多情况下会发生,例如调用 Object.wait()、Thread.sleep、Thread.join需要抛出InterruptedException的代码块,这里仅举出一些。他们都可能永久的阻塞线程。即使发生超时,在超时期满之前持续等待也是不可行和不适当的,所以,要使用某种机制使得线程更早地退出被阻塞的状态。这个时候你可以使用Thread.interrupt();

try {

JDK1.6 API:

while (!Thread.interrupted()) {

public void interrupt()Interrupts this thread.
Unless the current thread is interrupting itself, which is always permitted, the checkAccess method of this thread is invoked, which may cause a SecurityException to be thrown.
If this thread is blocked in an invocation of the wait(), wait(long), or wait(long, int) methods of the Object class, or of the join(), join(long), join(long, int), sleep(long), or sleep(long, int), methods of this class, then its interrupt status will be cleared and it will receive an InterruptedException.
If this thread is blocked in an I/O operation upon an interruptible channel then the channel will be closed, the thread's interrupt status will be set, and the thread will receive a ClosedByInterruptException.

/* do your block task*/

 

}

 

} catch (Exception e) {

public class BlockTask extends Thread {
    @Override
    public void run() {
        try {
            while (!Thread.interrupted()) {
                /* do your block task*/   
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
       
    }
}  
但是上面的代码或许有些不妥,或许用例子更能把问题说清楚。你怎么知道该代码段会发生阻塞?interrupt()函数到底是什么意思呢?
首先说明的是,interrupted()方法只能解决跑出InterruptedException异常的阻塞。而interrupt()并不是关闭阻塞线程,而且解除阻塞
那这里就举出一个关闭线程阻塞的例子把:

e.printStackTrace();

public class BlockTask extends Thread {
    @Override
    public void run() {
        try {
            sleep(10000);
        } catch (InterruptedException e) {
            System.out.println("if yout use interrupt you will see me");
        }
       
    }
    public static void main(String[] args)throws Exception {
        // TODO Auto-generated method stub
        BlockTask task = new BlockTask();
        task.start();
        Thread.sleep(1000);
        task.interrupt();
       
    }
}

}

3.上面说了,interrupt()只能解决InterruptedException的阻塞的线程,那么遇到一些其他的io阻塞怎么处理呢?这个时候java都会提供相应的关闭阻塞的办法。
例如,服务器可能需要等待一个请求(request),又或者,一个网络应用程序可能要等待远端主机的响应,这个时候可以使用套接字close()方法

}

public class SocketTask extends Thread {
    private volatile ServerSocket server;
   
    public void stopTask(){
        try {
            if(server!=null){
                server.close();
                System.out.println("close task successed");
            }
        } catch (IOException e) {
            System.out.println("close task failded");
        }
    }
    @Override
    public void run() {
        try {
            server = new ServerSocket(3333);
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
   
    public static void main(String[] args) throws InterruptedException {
       
        SocketTask task = new SocketTask();
        task.start();
        Thread.sleep(1000);
        task.stopTask();
    }

}

}
详细说明
程序是很简易的。然而,在编程人员面前,多线程呈现出了一组新的难题,如果没有被恰当的解决,将导致意外的行为以及细微的、难以发现的错误。

但是上面的代码或许有些不妥,或许用例子更能把问题说清楚。你怎么知道该代码段会发生阻塞?interrupt()函数到底是什么意思呢?首先说明的是,interrupted()方法只能解决跑出InterruptedException异常的阻塞。而interrupt()并不是关闭阻塞线程,而是解除阻塞。那这里就举出一个关闭线程阻塞的例子:
复制代码 代码如下:
public class BlockTask extends Thread {

在本篇文章中,我们针对这些难题之一:如何中断一个正在运行的线程。
                                                                                   
背景
    中断(Interrupt)一个线程意味着在该线程完成任务之前停止其正在进行的一切,有效地中止其当前的操作。
线程是死亡、还是等待新的任务或是继续运行至下一步,就取决于这个程序。
虽然初次看来它可能显得简单,但是,你必须进行一些预警以实现期望的结果。你最好还是牢记以下的几点告诫。

@Override

    首先,忘掉Thread.stop方法。虽然它确实停止了一个正在运行的线程,然而,这种方法是不安全也是不受提倡的,这意味着,在未来的JAVA版本中,它将不复存在。

public void run() {

    一些轻率的家伙可能被另一种方法Thread.interrupt所迷惑。尽管,其名称似乎在暗示着什么,然而,这种方法并不会中断一个正在运行的线程(待会将进一步说明),正如Listing A中描述的那样。它创建了一个线程,并且试图使用Thread.interrupt方法停止该线程。Thread.sleep()方法的调用,为线程的初始化和中止提供了充裕的时间。
线程本身并不参与任何有用的操作。

try {

class Example1 extends Thread {
            boolean stop=false;
      public static void main( String args[] ) throws Exception {
            Example1 thread = new Example1();
            System.out.println( "Starting thread..." );
            thread.start();
            Thread.sleep( 3000 );
            System.out.println( "Interrupting thread..." );
            thread.interrupt();
            Thread.sleep( 3000 );
            System.out.println("Stopping application..." );
            //System.exit(0);
            }
            public void run() {
            while(!stop){
            System.out.println( "Thread is running..." );
            long time = System.currentTimeMillis();
            while((System.currentTimeMillis()-time < 1000)) {
            }
            }
            System.out.println("Thread exiting under request..." );
            }
            }如果你运行了Listing A中的代码,你将在控制台看到以下输出:

sleep(10000);

Starting thread...

} catch (InterruptedException e) {

Thread is running...

System.out.println("if yout use interrupt you will see me");

Thread is running...

}

Thread is running...

}

Interrupting thread...

public static void main(String[] args)throws Exception {

Thread is running...

// TODO Auto-generated method stub

Thread is running...

BlockTask task = new BlockTask();

Thread is running...

task.start();

Stopping application...

Thread.sleep(1000);

Thread is running...

本文由威尼斯游戏网站发布于计算机编程,转载请注明出处:Java线程关闭的3种方法

关键词:

上一篇:JSP开发前菜鸟设置篇

下一篇:没有了

最火资讯