我有一个应用程序,当用户要求过滤图像时会生成一个新线程。
这是我唯一要做的任务,所有任务都同等重要。
如果我请求太多并发线程(我最多希望有9个),则线程管理器将抛出 RejectedExecutionException 。
在那一刻我要做的是;
// Manage Concurrent Tasks
private Queue> tasks = new LinkedList>();
@Override
public int remainingSize() {
return tasks.size();
}
@Override
public void addTask(AsyncTask task) {
try{
task.execute(currentThumbnail);
while(!tasks.isEmpty()){
task = tasks.remove();
task.execute(currentThumbnail);
}
} catch (RejectedExecutionException r){
Log.i(TAG,"Caught RejectedExecutionException Exception - Adding task to Queue");
tasks.add(task);
}
}
只需将被拒绝的任务添加到队列中,下次启动线程时,将检查队列以查看是否存在积压。
显而易见的问题是,如果最终任务在第一次尝试时被拒绝,它将永远不会重新启动(直到不再需要它为止)。
我只是想知道是否有一个简单的模型可以用来管理这种事情。我需要完成任务时通知队列。