1 Date
System.out.println(new java.util.Date()); //代码 输出:Thu Jan 27 14:43:28 CST 2011 System.out.println(new java.util.Date().toLocaleString()); //代码 输出:2011-1-27 14:45:21 。不过现在toLocaleString()方法已过时,由DateFormat.format(Date date)取代。 代码:
DateFormat ddf = DateFormat.getDateInstance(); DateFormat dtf = DateFormat.getTimeInstance(); DateFormat ddtf = DateFormat.getDateTimeInstance(); Date date = new Date(); System.out.println("日期:" + ddf.format(date)); System.out.println("时间:" + dtf.format(date)); System.out.println("日期时间:" + ddtf.format(date)); SimpleDateFormat sdf = (SimpleDateFormat) DateFormat.getDateTimeInstance(); System.out.println("日期时间:" + sdf.format(date)); 输出: 日期:2011-2-9 时间:11:16:02 日期时间:2011-2-9 11:16:02 日期时间:2011-2-9 11:16:02 以上是在window系统下,linux系统下不能这么处理,linux系统下用以上获取回来的初始时间格式与此不同。2 Timer & Timerask
两个类Timer和Timerask用于完成一个完整的定时任务。 Timer一种工具,线程用其安排以后再后台线程中执行的任务。可以安排任务执行一次,或者定期重复执行。由Timerask: Timer 安排一次执行或者从夫执行的任务。即:Timer是一种定时器工具,用来在一个后台线程计划执行指定任务,而Timerask是一个抽象类,它的子类是可以被Timer计划的任务。
(1)Timer Timer类可以保证多个线程可以共享单个Timer对象而无需进行外部同步,所以Timer类是线程安全的。但是由于每一个Timer对象对应的是单个后台线程,用于顺序执行所有的计时器任务,一般情况下我们的线程任务执行所消耗的时间应该非常短,但是由于特殊情况导致某个定时器任务执行的时间太长,那么他就会“独占”计时器的任务执行线程,其后的所有线程都必须等待它执行完,这就会延迟后续任务的执行,使这些任务堆积在一起,
(2) Timerask TimerTask类是一个抽象类,由Timer安排为一次执行或重复执行的任务。它有一个抽象方法run()方法,该方法用于执行相应计时器任务要执行的操作。因此每一个具体的任务类都必须继承TimerTask,然后重写run()方法。
3 schedule
方法注释schedule(TimerTask task, Date time)安排在指定的时间执行指定的任务schedule(TimerTask task, Date firstTime, long period)安排指定的任务在指定的时间开始进行重复的固定延迟执行schedule(TimerTask task, long delay)安排在指定延迟后执行指定的任务schedule(TimerTask task, long delay, long period)安排指定的任务从指定的延迟后开始进行重复的固定延迟执行scheduleAtFixedRate(TimerTask task, Date firstTime, long period)安排指定的任务在指定的时间开始进行重复的固定速率执行scheduleAtFixedRate(TimerTask task, long delay, long period)安排指定的任务在指定的延迟后开始进行重复的固定速率执行同时也重载了scheduleAtFixedRate方法,scheduleAtFixedRate方法与schedule相同,只不过他们的侧重点不同,区别后面分析。
另外它还有两个非抽象的方法:
boolean cancel();//取消此计时器任务。 long scheduledExecutionTime();//返回此任务最近实际执行的安排执行时间。