读书人

java惯用组件-线程池

发布时间: 2012-11-07 09:56:10 作者: rapoo

java常用组件--线程池

/*
* 创建日期 2005-12-7
*/
package cn.com.skyon.sms.awork;

import org.apache.log4j.Logger;

import cn.com.skyon.sms.Other.DataContainer;
/**
* 线程池中的执行者
* @author ghl
*/
public class Peon implements Runnable
{
private static Logger logger = Logger.getLogger(Peon.class);
private DataContainer container = DataContainer.getInstance();
public void run()
{
while(!Thread.currentThread().isInterrupted())
{
try
{
Runnable runnable ;
synchronized (container)
{
try
{
while (container.executorSize() == 0 && !Thread.currentThread().isInterrupted())
{
try
{
container.wait();
}
catch (InterruptedException e)
{
}
}
runnable = container.popExecutor();
}
finally
{
container.notifyAll();
}
}
if (runnable != null)
{
logger.info("成功获得执行器,开始执行……");
runnable.run();
logger.info("执行完毕");
}
}
catch (Exception e)
{
logger.error("执行期间出现错误",e);
}
}
logger.info("执行线程结束");
}
}

读书人网 >编程

热点推荐