`
micheal19840929
  • 浏览: 167244 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

[原创]多线程之队列式执行任务

    博客分类:
  • J2SE
阅读更多

      前言:最近做的一个项目正好要用到多线程,而且要实现队列式处理,即外界可向线程添加任务,同时一旦队列中有任务时,线程自动启动对之进行处理。要求任务的添加与执行要同步处理。最终结果如下:

[TaskThread.java]

import java.util.HashMap;
import java.util.Vector;

/**
* Task Processing Thread.It is enable to add Task and perform task synchronously.
* All tasks is restored in the task queue.
* If there is task(s) in the task queue,it(them) will be performed by the thread automaticlly.
* Or the thread will be turned into waiting for waking.
* <br>
* Mode:Multiton Mode
* <br>
* 任务处理线程,实现同步添加及执行任务,任务保存在任务队列之中.
* 当任务队列中存在任务时,线程将自动对其进行处理;否则线程进入等待状态.
* <br>
* 模式:多例模式
* @author Micheal Hong
* @email babala_234@163.com
* @see Task
*/
public class TaskThread extends Thread{

private static HashMap<String,TaskThread> instanceMap=new HashMap<String,TaskThread>();

private Vector<Task> taskQueue=new Vector<Task>();
private boolean runnable=true;

/**
* Return a task thread instance corresponding to threadId,
* if it don't exist,create one and return it.
* Note that each <code>threadId</code> is unique to the others.
* <br>
* 返回一个与threadId对应的任务处理线程实例,如果不存在这样的实例,
* 则进行创建并返回一个新实例,新实例与threadId相对应
* @param threadId
* @return
*/
public static TaskThread getInstance(String threadId)
{
   if(instanceMap.containsKey(threadId)==false)
   {
    instanceMap.put(threadId,new TaskThread());
   }
   return instanceMap.get(threadId);
}

private TaskThread()
{}

@Override
public void run() {
   Task task;
   while(runnable)
   {
    synchronized (taskQueue) {   //apply for the task queue's obj lock
     while(taskQueue.isEmpty())
     {
      taskQueue.notify();   //release the task queue's obj lock
      try {
       taskQueue.wait(); //turn into waiting for being waken
      } catch (InterruptedException e) {
       e.printStackTrace();
      }
     }
     /*when the task queue is not empty*/
     task=taskQueue.remove(0); //fetch the head task
     taskQueue.notify();    //release the task queue's obj lock
    }
    task.perform();      //perform the task
   }
}

/**
* Add task into task queue synchronously and then wake the task thread.
* <br>
* 向任务队列添加任务并唤醒线程对队列进行处理
* @param task
*/
public void addTask(Task task)
{
   synchronized (taskQueue) {   //apply for the task queue's obj lock
    taskQueue.add(task);
    taskQueue.notify();    //release the task queue's obj lock
   }
}

}

 

[Task.java]

/**
* Task Entry
* 任务实体
* Mode:Template Mode
* 模式:模板模式
* @author Micheal Hong
*
*/
public abstract class Task {
protected String projectId;

public Task(String projectId)
{
   this.projectId=projectId;
}

public String getProjectId() {
   return projectId;
}

/**
* task performance.It is an interface supplied for implemented by caller.
* 任务的执行。由调用者自行实现。
* @see TaskThread
*/
public abstract void perform();

}

 

以上代码都已经过测试,呵呵,一个简单的线程雏形,希望对初学者有所帮助,算是抛砖引玉吧。

分享到:
评论

相关推荐

    【原创】C#多线程_跨线程窗体同步_进度条_生产消费(源代码)

    本项目"【原创】C#多线程_跨线程窗体同步_进度条_生产消费(源代码)"就是针对这一主题的一个实践示例,旨在帮助开发者理解如何在WinForm应用中实现多线程操作,并有效地管理跨线程数据安全以及展示进度。...

    android多线程下载原创代码

    在Android开发中,多线程技术是至关重要的,特别是在处理耗时操作如网络下载时,为了提高用户体验,我们通常会采用多线程来避免主线程(UI线程)被阻塞。本篇将深入探讨如何在Android中实现多线程下载,基于提供的...

    C#基于异步事件回调多线程容器

    代码采用多工作者多线程执行任务。通过暴露的方法往工作者传递消息,然后采用事件回调返回处理结果,实现的事件有OnThreadComplete,OnAddedTask,OnStart,OnSuccess,OnFailure,OnTimeout。 事件回调支持同步或...

    易语言-易语言真正的线程池简易实现

    3.执行任务的线程等待队列,如果队列中有任务,则执行任务,如果队列中没有任务,则进入内核等待状态,当队列中有任务时继续执行。而不是重复性创建和销毁线程。 具体请看上图。 三.线程句柄的管理 每次新建线程时...

    应用源码之HandlerSample.zip

    这份源码学习资料,旨在帮助开发者提升对Android多线程编程的理解,特别是对Handler、Looper和Message的运用。 首先,HandlerSample项目的核心是展示了如何使用Handler、Looper和Message进行线程间的通信。Handler...

    〔原创〕Android消息传递机制(总结)

    总之,Android的消息传递机制是其多线程编程的核心,通过Handler、Message、Looper和MessageQueue的协同工作,实现了线程间的通信和任务调度。深入理解这一机制,对于编写高效、响应迅速的Android应用至关重要。

    定时提醒器(原创)

    8. **多线程**:如果提醒器需要在后台运行并独立于用户界面执行提醒,那么可能涉及到多线程编程。一个线程负责监控时间,到达设定的提醒点时,另一个线程负责弹出提醒窗口。 9. **通知机制**:提醒器可能使用了...

    进程管理 程序 绝对可运行

    7. **多线程**:在C++中,可以使用`std::thread`库创建和管理线程,线程是轻量级进程,共享同一进程的内存空间。代码可能涉及到线程的创建、同步和销毁。 这个压缩包中的源代码提供了实践操作系统进程管理原理的...

    FTP上传工具.rar

    3. 任务队列:允许用户预设一系列上传任务,并在后台自动执行。 4. 断点续传:如果文件传输中断,可以从上次断开的地方继续,避免重新上传。 5. 安全性:支持FTP over TLS/SSL(FTPS)或SSH File Transfer Protocol...

    达内Unix_Linux 核心编程课件ppt.pdf

    多线程是一种编程方法,允许多个线程在单个进程的地址空间中执行任务,这样可以利用多核CPU的计算能力,并提高程序的执行效率。在Unix/Linux中,线程的创建和管理需要对pthread库有一定的了解。 网络通信是指通过...

    winrar3.7 Beta8

    多线程默认被启用,但是你可以在 “设置”对话框的“常规”部分中禁用它。 在命令行模式你可以使用 -mt&lt;线程&gt; 开关控制多线程。 &lt;br&gt; 2. WinRAR 可以显示文件夹树面板来在磁盘和文件夹目录中导航。...

    windows驱动开发技术详解-part2

     8.5.2 内核模式下开启多线程  8.5.3 内核模式下的事件对象  8.5.4 驱动程序与应用程序交互事件对象  8.5.5 驱动程序与驱动程序交互事件对象  8.5.6 内核模式下的信号灯  8.5.7 内核模式下的互斥体  ...

    Windows驱动开发技术详解的光盘-part1

     8.5.2 内核模式下开启多线程  8.5.3 内核模式下的事件对象  8.5.4 驱动程序与应用程序交互事件对象  8.5.5 驱动程序与驱动程序交互事件对象  8.5.6 内核模式下的信号灯  8.5.7 内核模式下的互斥体  ...

    Maze.rar_Java编程_Java_

    4. **多线程**:Java的并发处理能力使游戏能够同时执行多个任务,如背景音乐播放、动画更新和游戏逻辑计算,确保游戏流畅运行。 5. **文件I/O**:为了保存游戏进度、读取配置文件或者加载游戏资源(如图像、音频)...

    PACC:Jed Chen、Alex Kiral、Nathaniel Li PACC 竞赛项目

    6. **多线程**:用于并发执行任务,提高程序效率。 7. **算法与数据结构**:如排序算法(冒泡、选择、插入、快速、归并)、搜索算法(二分查找、广度优先搜索、深度优先搜索)以及常用数据结构(栈、队列、树、图)...

Global site tag (gtag.js) - Google Analytics