网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > Java
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.Eclipse开发struts完全指南一(全.
.log4j--新的日志操作方法.
.TotalSize 属性.
.tomcat5中文问题解决之道.
.全面解析JDBC(3).
.重新“掷”出违例.
.用Java实现股票走势图.
.JDK6的新特性:脚本语言支持(Scri.
.Servlet简介.
.WindowsXP 下 JDK 的配置.
.使用AdminScripts脚本创建虚拟目.
.让第一个jdo的应用跑起来.
.IsRootFolder 属性.
.JDK5.0环境下配置PKCS#11.
.JavaBean实现航空预定机票功能应.
.Sequoia 2.5 发布-JD.
.What is AspectJ.
.Think in java 3rd 中文版12_13.
.Servlet + Tomcat 中文乱码的原理.
.全面挖掘Java Excel API 使用方法.

基于Java线程实现后台定时监控

发表日期:2008-6-23


http://tailsherry.javaeye.com/blog/176152

熟悉编写JavaScript的人,都习惯在页面写入setTimeOut来实现web页面的定时监控或事务处理。但是如何在Java服务端来实现这样一个监控机制呢?一般大家都会想到线程。但是一直以来,都没有亲身动手实践过。趁着工作间隙,自己也搬出一段代码来,与大家一起分享线程编程的神奇魔力。

 

首先创建一个基本抽象类SchedThread,代码内容如下:

view plaincopy to clipboardprint?
package com.test;  
 
/** 
 * 基于Java线程实现后台定时监控 <P> Created: Mar 26, 2008 10:08:43 </P><P> 
 * </P><H4>http://tailsherry.javaeye.com</H4> 
 * <P> 
 *  
 * @author TailSherry 
 */ 
public abstract class SchedThread  
{  
    protected static final long NEVER = Long.MAX_VALUE;  
 
    // 定义一个线程锁,保证当前只有一个工作在操作中  
    private final Object lock = new Object();  
 
    // 定义一个Thread变量  
    private Thread thread;  
 
    // 控制线程循环的开关  
    private boolean active = true;  
 
    // 定义一个毫秒级的时间变量,指示何时执行下一个操作  
    private long nextTime;  
 
    /** 
     * 定义个一个抽象的方法用来获取下一个执行操作的时间,可使用NEVER 
     */ 
    protected abstract long getNextTime();  
 
    /** 
     * 定义一个抽象的方法,让子类来定义具体的工作过程 
     */ 
    protected abstract void executeWork();  
 
    protected String getName()  
    {  
        return getClass().getName();  
    }  
 
    /** 
     * 启动线程 
     */ 
    public void start()  
    {  
        thread = new Thread(new Runnable()  
        {  
            public void run()  
            {  
                runInternal();  
            }  
        }, getName());  
        thread.start();  
    }  
 
    /** 
     * 强迫停止线程,跳出for循环 
     */ 
    public void stop() throws InterruptedException  
    {  
        synchronized (lock)  
        {  
            active = false;  
            lock.notify();  
        }  
        thread.join();  
    }  
 
    /** 
     * 此方法可以在任何时候激活当前线程,让线程进入工作执行环节 
     */ 
    public void workAdded(long time)  
    {  
        synchronized (lock)  
        {  
            if (time < nextTime)  
            {  
                // 立刻激活线程工作继续运行  
                lock.notify();  
            }  
        }  
    }  
 
    /** 
     * 线程监测控制逻辑部分 
     */ 
    private void runInternal()  
    {  
        // 无限循环  
        for (;;)  
        {  
            // 该过程忽略了所有的Exception,以保证线程不会因此而中断  
            try 
            {  
                synchronized (lock)  
                {  
                    nextTime = getNextTime();  
                    // 获得时间区间,即要等待的时间段  
                    long interval = nextTime - System.currentTimeMillis();  
                    if (interval > 0)  
                    {  
                        try 
                        {  
                            lock.wait(interval);  
                        }  
                        catch (InterruptedException e)  
                        {  
                            // 忽略此Exception  
                        }  
                    }  
                    // 如果active为false,强制中断  
                    if (!active)  
                    {  
                        break;  
                    }  
                }  
                // 执行具体的工作  
                executeWork();  
            }  
            catch (Throwable t)  
            {  
                try 
                {  
                    Thread.sleep(10000);  
                }  
                catch (InterruptedException ie)  
                {  
                    // 忽略此Exception  
                }  
            }  
        }  
    }  
}</P> 

package com.test;

/**
 * 基于Java线程实现后台定时监控  Created: Mar 26, 2008 10:08:43
 * http://tailsherry.javaeye.com
 *
 *
 * @author TailSherry
 */
public abstract class SchedThread
{
    protected static final long NEVER = Long.MAX_VALUE;

    // 定义一个线程锁,保证当前只有一个工作在操作中
    private final Object lock = new Object();

    // 定义一个Thread变量
    private Thread thread;

    // 控制线程循环的开关
    private boolean active = true;

    // 定义一个毫秒级的时间变量,指示何时执行下一个操作
    private long nextTime;

    /**
     * 定义个一个抽象的方法用来获取下一个执行操作的时间,可使用NEVER
     */
    protected abstract long getNextTime();

    /**
     * 定义一个抽象的方法,让子类来定义具体的工作过程
     */
    protected abstract void executeWork();

    protected String getName()
    {
        return getClass().getName();
    }

    /**
     * 启动线程
     */
    public void start()
    {
        thread = new Thread(new Runnable()
        {
            public void run()
            {
                runInternal();
            }
        }, getName());
        thread.start();
    }

    /**
     * 强迫停止线程,跳出for循环
     */
    public void stop() throws InterruptedException
    {
        synchronized (lock)
        {
            active = false;
            lock.notify();
        }
        thread.join();
    }

    /**
     * 此方法可以在任何时候激活当前线程,让线程进入工作执行环节
     */
    public void workAdded(long time)
    {
        synchronized (lock)
        {
            if (time < nextTime)
            {
                // 立刻激活线程工作继续运行
                lock.notify();
            }
        }
    }

    /**
     * 线程监测控制逻辑部分
     */
    private void runInternal()
    {
        // 无限循环
        for (;;)
        {
            // 该过程忽略了所有的Exception,以保证线程不会因此而中断
            try
            {
                synchronized (lock)
                {
                    nextTime = getNextTime();
                    // 获得时间区间,即要等待的时间段
                    long interval = nextTime - System.currentTimeMillis();
                    if (interval > 0)
                    {
                        try
                        {
                            lock.wait(interval);
                        }
                        catch (InterruptedException e)
                        {
                            // 忽略此Exception
                        }
                    }
                    // 如果active为false,强制中断
                    if (!active)
                    {
                        break;
                    }
                }
                // 执行具体的工作
                executeWork();
            }
            catch (Throwable t)
            {
                try
                {
                    Thread.sleep(10000);
                }
                catch (InterruptedException ie)
                {
                    // 忽略此Exception
                }
            }
        }
    }
}

以上这个类非常关键,基本上已经实现了所有的控制逻辑,如此再扩展出一个实现类出来,比如这里我写了一个模拟实现类MyDataGenerator,大家可以参考一下:

Java代码 view plaincopy to clipboardprint?
  

 view plaincopy to clipboardprint?
package com.test;     
    
public class MyDataGenerator extends SchedThread {     
    protected void executeWork() {     
        System.out.println("Execute work ...");     
    }     
    
    protected long getNextTime() {     
        return System.currentTimeMillis() + 2000L;     
    }     
    
    public static void main(String argv[]) {     
        MyDataGenerator generator = new MyDataGenerator();     
        generator.start();     
    }     
}   

package com.test;  
 
public class MyDataGenerator extends SchedThread {  
    protected void executeWork() {  
        System.out.println("Execute work ...");  
    }  
 
    protected long getNextTime() {  
        return System.currentTimeMillis() + 2000L;  
    }  
 
    public static void main(String argv[]) {  
        MyDataGenerator generator = new MyDataGenerator();  
        generator.start();  
    }  

当然这里没有使用workAdded和stop等功能,可以留给大家扩展。

上一篇:在java 中执行触发器代码、创表语句 人气:1783
下一篇:Linux环境下Java开发 Linux和Windows比较 人气:1605
浏览全部Java的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐