前言:最近做的一个项目正好要用到多线程,而且要实现队列式处理,即外界可向线程添加任务,同时一旦队列中有任务时,线程自动启动对之进行处理。要求任务的添加与执行要同步处理。最终结果如下:
[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#多线程_跨线程窗体同步_进度条_生产消费(源代码)"就是针对这一主题的一个实践示例,旨在帮助开发者理解如何在WinForm应用中实现多线程操作,并有效地管理跨线程数据安全以及展示进度。...
在Android开发中,多线程技术是至关重要的,特别是在处理耗时操作如网络下载时,为了提高用户体验,我们通常会采用多线程来避免主线程(UI线程)被阻塞。本篇将深入探讨如何在Android中实现多线程下载,基于提供的...
代码采用多工作者多线程执行任务。通过暴露的方法往工作者传递消息,然后采用事件回调返回处理结果,实现的事件有OnThreadComplete,OnAddedTask,OnStart,OnSuccess,OnFailure,OnTimeout。 事件回调支持同步或...
3.执行任务的线程等待队列,如果队列中有任务,则执行任务,如果队列中没有任务,则进入内核等待状态,当队列中有任务时继续执行。而不是重复性创建和销毁线程。 具体请看上图。 三.线程句柄的管理 每次新建线程时...
这份源码学习资料,旨在帮助开发者提升对Android多线程编程的理解,特别是对Handler、Looper和Message的运用。 首先,HandlerSample项目的核心是展示了如何使用Handler、Looper和Message进行线程间的通信。Handler...
总之,Android的消息传递机制是其多线程编程的核心,通过Handler、Message、Looper和MessageQueue的协同工作,实现了线程间的通信和任务调度。深入理解这一机制,对于编写高效、响应迅速的Android应用至关重要。
8. **多线程**:如果提醒器需要在后台运行并独立于用户界面执行提醒,那么可能涉及到多线程编程。一个线程负责监控时间,到达设定的提醒点时,另一个线程负责弹出提醒窗口。 9. **通知机制**:提醒器可能使用了...
7. **多线程**:在C++中,可以使用`std::thread`库创建和管理线程,线程是轻量级进程,共享同一进程的内存空间。代码可能涉及到线程的创建、同步和销毁。 这个压缩包中的源代码提供了实践操作系统进程管理原理的...
3. 任务队列:允许用户预设一系列上传任务,并在后台自动执行。 4. 断点续传:如果文件传输中断,可以从上次断开的地方继续,避免重新上传。 5. 安全性:支持FTP over TLS/SSL(FTPS)或SSH File Transfer Protocol...
多线程是一种编程方法,允许多个线程在单个进程的地址空间中执行任务,这样可以利用多核CPU的计算能力,并提高程序的执行效率。在Unix/Linux中,线程的创建和管理需要对pthread库有一定的了解。 网络通信是指通过...
多线程默认被启用,但是你可以在 “设置”对话框的“常规”部分中禁用它。 在命令行模式你可以使用 -mt<线程> 开关控制多线程。 <br> 2. WinRAR 可以显示文件夹树面板来在磁盘和文件夹目录中导航。...
8.5.2 内核模式下开启多线程 8.5.3 内核模式下的事件对象 8.5.4 驱动程序与应用程序交互事件对象 8.5.5 驱动程序与驱动程序交互事件对象 8.5.6 内核模式下的信号灯 8.5.7 内核模式下的互斥体 ...
8.5.2 内核模式下开启多线程 8.5.3 内核模式下的事件对象 8.5.4 驱动程序与应用程序交互事件对象 8.5.5 驱动程序与驱动程序交互事件对象 8.5.6 内核模式下的信号灯 8.5.7 内核模式下的互斥体 ...
4. **多线程**:Java的并发处理能力使游戏能够同时执行多个任务,如背景音乐播放、动画更新和游戏逻辑计算,确保游戏流畅运行。 5. **文件I/O**:为了保存游戏进度、读取配置文件或者加载游戏资源(如图像、音频)...
6. **多线程**:用于并发执行任务,提高程序效率。 7. **算法与数据结构**:如排序算法(冒泡、选择、插入、快速、归并)、搜索算法(二分查找、广度优先搜索、深度优先搜索)以及常用数据结构(栈、队列、树、图)...