首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > JAVA > J2EE开发 >

多线程异步执行有关问题

2013-11-29 
多线程异步执行问题在我的项目的applicationContext.xml配置文件中有如下配置:bean idAsynService cla

多线程异步执行问题
在我的项目的applicationContext.xml配置文件中有如下配置:
<bean id="AsynService" class="com.strongit.nj.zdjr.common.asyn4j.spring.AsynServiceFactoryBean">
    <!--设置自定义相关参数-->
    <property name="maxCacheWork" value="10000"></property><!--最大工作队列缓存工作数-->
<property name="addWorkWaitTime" value="2000"></property><!--当工作队列满时添加工作等待时间-->
<property name="workThreadNum" value="50"></property><!--异步工作执行线程池大小 -->
<property name="callbackThreadNum" value="100"></property><!--回调执行线程池大小-->
<property name="closeServiceWaitTime" value="2000"></property><!--服务关闭等待时间-->
<!--添加相关处理器-->
<property name="errorAsynWorkHandler"><!-- 异步工作执行异常处理器 -->
<bean class="com.strongit.nj.zdjr.common.asyn4j.core.handler.DefaultErrorAsynWorkHandler"/>
    </property>
<property name="workQueueFullHandler"><!--异步工作缓冲处理器 -->
<bean class="com.strongit.nj.zdjr.common.asyn4j.core.handler.CacheAsynWorkHandler"/>
   </property>
   <property name="asynServiceCloseHandler"><!--服务器启动和关闭处理器  -->
            <bean class="com.strongit.nj.zdjr.common.asyn4j.core.handler.FileAsynServiceHandler"/>
       </property>
   </bean>

这是java提供的异步方法调用的相关配置,回调类TargetBack是这样的:

public class TargetBack extends AsynCallBack {
private static final Logger logger = Logger.getLogger(TargetBack.class);
private static final long serialVersionUID = -7226571806577095229L;

private JSONArray dcArray;

public TargetBack(JSONArray dcArray) {
this.dcArray= dcArray;
}

@Override
    public void doNotify() {
   Boolean result = (Boolean) methodResult;
     if (result) {
  for(int j = 0; j < dcArray.size(); j++) {
  jsonObject = dcArray.getJSONObject(j);
  dcxtHelper.savedcxt(jsonObject.getString("dcName"));  
         }
  }
  }
}


我的疑问是配置文件中callbackThreadNum配置,对回调类中的doNotify方法执行起到什么作用呢?(我猜测开了很多线程所以能快速处理循环,但是问题是,每个线程都做这个循环方法?又说不通)
有知道的大神们给小弟讲解下, 知道多少讲多少,小弟不胜感激啊!--疑惑很久了,等待你们的解答!
[解决办法]
这个问题提的很好,楼主猜测的有一定的道理,但是你的疑问我就不懂了,顶个,等待高手进来。
[解决办法]
你提交一个任务,就会被分配一个线程去执行.那么你同时提交了两个呢?难道让另一个进行等待?

当然是一起执行,那就需要两个线程了.那答案就出来了"callbackThreadNum"就是设定最大同时能有多少个任务同时执行.

热点排行