主要原理:
一、 ThreadPoolManager在实例化时创建十个线程,放入Vector中。
二、 每个SimpleThread线程的是否在运行的标记runningFlag设置为false。
三、 当使用ThreadPoolManager的process方法处理时,遍历Vector中的线程,如果当前遍历到的线程不在运行中,则使用当前线程,并设置运行标记runningFlag为true。
四、 当前线程的运行标记位为false时,线程wait(),为true时开始处理字符串。
五、 为了使得线程运行时每个线程独占一个任务,在SimpleThread的run()方法中使线程sleep(5000),这样一个线程接手一个任务后,在睡眠期间再来其他任务由下个标记为false的线程接手。
代码如下:
// SimpleThread:
public class SimpleThread extends Thread {
private boolean runningFlag;
private String argument;
public boolean isRunning() {
return runningFlag;
}
public synchronized void setRunning(boolean flag) {
runningFlag = flag;
if (flag) {
this.notify();
}
}
public String getArgument() {
return argument;
}
public void setArgument(String string) {
argument = string;
}
public SimpleThread(int threadNumber) {
runningFlag = false;
System.out.println("thread " + threadNumber + " started;");
}
public synchronized void run() {
try {
while (true) {
if (!runningFlag) {
this.wait();
} else {
System.out.println("processing: " + getArgument() + "..done");
sleep(5000);
System.out.println("thread is sleeping");
setRunning(false);
}
}
} catch (InterruptedException e) {
System.out.println("InterruptedException");
}
}
}
//ThreadPoolManager:
public class ThreadPoolManager {
private int maxThread;
public Vector vector;
public void setMaxThread(int threadCount) {
maxThread = threadCount;
}
public ThreadPoolManager(int threadCount) {
setMaxThread(threadCount);
System.out.println("starting thread pool....");
vector = new Vector();
for (int i = 0; i < 10; i++) {
SimpleThread thread = new SimpleThread(i);
vector.addElement(thread);
thread.start();
}
}
public void process(String argument) {
int i;
for (i = 0; i < vector.size(); i++) {
SimpleThread currentThread = (SimpleThread) vector.elementAt(i);
if (!currentThread.isRunning()) {
System.out.println("thread" + (i + 1) + "is processing::"
+ argument);
currentThread.setArgument(argument);
currentThread.setRunning(true);
break;
}
if (i == (vector.size() - 1)) {
System.out.println("pool is full,try in another time.");
}
}
}
}
//测试类
public class TestThreadPool {
public static void main(String[] args) {
try {
BufferedReader br = new BufferedReader(new InputStreamReader(
System.in));
String s;
ThreadPoolManager manager = new ThreadPoolManager(10);
while ((s = br.readLine()) != null) {
manager.process(s);
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
分享到:
相关推荐
下面是一段简单的C++线程池实现示例: ```cpp #include <vector> #include #include #include #include class ThreadPool { std::vector<std::thread> workers; std::queue()>> tasks; std::mutex queue_...
本文将深入探讨如何在Visual Studio 2015(VS2015)环境下实现一个简单的线程池,并解析提供的`TestThreadPool.sln`解决方案和`TestThreadPool`源代码文件。 线程池的基本思想是维护一组预先创建的线程,这些线程...
下面我们将详细探讨如何在VC++中构建一个简单的线程池。 首先,线程池的核心组件包括: 1. **线程池对象**:这是管理所有线程的容器,负责线程的创建、调度和销毁。 2. **任务队列**:线程池中存放待处理任务的...
线程池容器一般使用`std::vector`或`std::deque`来存储线程对象,任务队列则可以使用`std::queue`或者`std::priority_queue`。 2. **线程类**:每个线程需要负责从任务队列中取出任务并执行。这通常通过一个无限...
以下是一个简单的线程池实现框架: ```cpp #include #include <vector> #include #include #include class ThreadPool { public: ThreadPool(size_t numThreads); ~ThreadPool(); template, typename... ...
本教程将深入探讨如何在Linux环境下,使用C++实现一个简单的线程池。 首先,线程池的基本结构通常包括以下几个部分: 1. **线程池容器**:用于存储工作线程的集合,通常使用STL中的`std::vector`来实现。这个容器...
下面是一个简单的C++线程池实现示例: ```cpp #include #include <vector> #include #include #include class ThreadPool { public: ThreadPool(size_t numThreads) : stopped(false) { for (size_t i = 0; ...
这个简单的C++线程池实现展示了如何在Linux环境下高效地管理和调度线程,通过使用线程池,我们可以更好地控制并发执行的任务数量,提高系统资源的利用率,并简化多线程编程的复杂性。理解并能应用这样的线程池设计,...
下面是一个简单的C++线程池实现框架: ```cpp #include #include #include #include class ThreadPool { private: std::vector<std::thread> workers; std::queue()>> tasks; std::mutex queue_mutex; std...
本文将详细介绍如何使用Java语言来构建一个简单的线程池,并深入分析其实现原理与关键细节。 #### 一、线程池的概念 线程池是一种基于池化技术的设计模式,其核心思想是在程序启动时创建一定数量的线程放入池中供...
以下是一个简单的线程池实现框架: 1. **线程池类定义**:首先定义一个线程池类,包含任务队列、线程集合、同步原语等成员变量。 2. **构造函数**:初始化线程池,创建一定数量的工作线程。 3. **提交任务**:提供...
这是一个简单的线程池类定义,包含了线程池的基本属性和方法。 ##### 4.2 属性定义 ```java public static final int MAX_THREADS = 100; public static final int MAX_SPARE_THREADS = 50; public static final ...
在给定的代码示例中,`ThreadPool` 类是一个简单的线程池实现,它包含以下几个关键组件: 1. `pool`: 一个 `Vector` 对象,用于存储空闲线程。当线程完成任务后,它们会返回到池中,等待被重新分配新的任务。 2. `...
本文将深入探讨线程池的概念、实现原理以及如何在Ubuntu/Linux环境下使用C++进行线程池的编程。 线程池的核心概念在于“池化”资源,即维护一组线程,这些线程处于待命状态,随时准备处理到来的任务。当有新的任务...
总结来说,C++线程池的简单实现涉及线程的创建、管理以及同步机制的使用。理解这些基本概念和API是实现高效线程池的关键,而线程池的设计则需要考虑任务调度策略、资源管理以及线程间的通信问题。在实际项目中,可以...
下面是一个简单的线程池实现: ```cpp class threadpool { using Task = std::function()>; std::vector<std::thread> pool; // 线程池 std::queue<Task> tasks; // 任务队列 std::mutex m_lock; // 同步 std...