java的timer类如何判断程序超时呢?

Python054

java的timer类如何判断程序超时呢?,第1张

参照如下的:

Timer类是用来执行任务的类,它接受一个TimerTask做参数

TimerTask是个抽象类,他扩展了Object并实现了Runnable接口,因此你必须在自己的Task中实现publicvoid run()方法。这也就是我们需要执行的具体任务。

Timer有两种执行任务的模式,最常用的是schedule,它可以以两种方式执行任务:1:在某个时间(Data),2:在某个固定的时间之后(intdelay).这两种方式都可以指定任务执行的频率

我们指定一个线程A,调用对象B.wait(timeout),线程A就会阻塞,直到timeout到了,B醒来会使A继续执行。

其实Timer类是为多任务定时设计的,在实现里面,B是一个任务队列(实现上就是一个array),维护着所有使用当前Timer定时的任务,它们可是一堆货真价实的线程实例。每次线程A都取队列中距离当前时间最近的的定时任务,跟当前时间比较,然后wait(timeout)这段时间。线程唤醒的时刻也是队列中这个定时任务运行的时刻。然后线程继续取下一个定时任务,继续wait(timeout)。从这里我们能看出来,每次定时都有额外的时间开销,比如要维护队列等,所以Java的Timer类不保证实时。

Timer中最主要由三个部分组成:

任务TimerTask 、 任务队列: TaskQueue queue 和 任务调试者:TimerThreadthread

Timer对任务的调度是基于绝对时间的。

所有的TimerTask只有一个线程TimerThread来执行,因此同一时刻只有一个TimerTask在执行。

任何一个TimerTask的执行异常都会导致Timer终止所有任务。

由于基于绝对时间并且是单线程执行,因此在多个任务调度时,长时间执行的任务被执行后有可能导致短时间任务快速在短时间内被执行多次或者干脆丢弃多个任务。

由于Timer/TimerTask有这些特点(缺陷),因此这就导致了需要一个更加完善的任务调度框架来解决这些问题。

默认情况下,只要一个程序的timer线程在运行,那么这个程序就会保持运行。当然,你可以通过以下四种方法终止一个timer线程:

调用timer的cancle方法。你可以从程序的任何地方调用此方法,甚至在一个timertask的run方法里。

让timer线程成为一个daemon线程(可以在创建timer时使用newTimer(true)达到这个目地),这样当程序只有daemon线程的时候,它就会自动终止运行。

当timer相关的所有task执行完毕以后,删除所有此timer对象的引用(置成null),这样timer线程也会终止。

调用System.exit方法,使整个程序(所有线程)终止。

java 1.5以上的Future类可以执行超时处理。

jdk1.5自带的并发库中Future类中重要方法包括get()和cancel(),get()获取数据对象,如果数据没有加载,就会阻塞直到取到数据,而 cancel()是取消数据加载。另外一个get(timeout)操作,表示如果在timeout时间内没有取到就失败返回,而不再阻塞。

代码如下:

import java.util.concurrent.Callable

import java.util.concurrent.ExecutionException

import java.util.concurrent.ExecutorService

import java.util.concurrent.Executors

import java.util.concurrent.TimeUnit

import com.sun.corba.se.impl.orbutil.closure.Future

import com.sun.corba.se.impl.orbutil.threadpool.TimeoutException

public class ThreadTest {  

  

    public static void main(String[] args) throws InterruptedException,  

            ExecutionException {  

          

        final ExecutorService exec = Executors.newFixedThreadPool(1)  

          

        Callable<String> call = new Callable<String>() {  

            public String call() throws Exception {  

                //开始执行耗时操作  

                Thread.sleep(1000 * 5)  

                return "线程执行完成."  

            }  

        }  

          

        try {  

            Future<String> future = exec.submit(call)  

            String obj = future.get(1000 * 1, TimeUnit.MILLISECONDS) //任务处理超时时间设为 1 秒  

            System.out.println("任务成功返回:" + obj)  

        } catch (TimeoutException ex) {  

            System.out.println("处理超时啦....")  

            ex.printStackTrace()  

        } catch (Exception e) {  

            System.out.println("处理失败.")  

            e.printStackTrace()  

        }  

        // 关闭线程池  

        exec.shutdown()  

    }  

}

你说的是请求没有响应吧,首先检查服务器有没有错误的log,如果是调试,看看是不是存在断点,如果不是这两种情况,那么代码肯定是存在一定的问题,需要细心的排除代码哪里停住了,一般不会是直接的执行错误,执行错误页面会返回错误的页面比如404,500等等