`
forhope
  • 浏览: 366466 次
  • 性别: Icon_minigender_1
  • 来自: 帝都
社区版块
存档分类
最新评论

使用Vector实现简单线程池

阅读更多
主要原理:
   一、 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++ 实现的线程池(linux环境下)

    下面是一段简单的C++线程池实现示例: ```cpp #include &lt;vector&gt; #include #include #include #include class ThreadPool { std::vector&lt;std::thread&gt; workers; std::queue()&gt;&gt; tasks; std::mutex queue_...

    c++简单线程池的实现

    本文将深入探讨如何在Visual Studio 2015(VS2015)环境下实现一个简单的线程池,并解析提供的`TestThreadPool.sln`解决方案和`TestThreadPool`源代码文件。 线程池的基本思想是维护一组预先创建的线程,这些线程...

    线程池  

    下面我们将详细探讨如何在VC++中构建一个简单的线程池。 首先,线程池的核心组件包括: 1. **线程池对象**:这是管理所有线程的容器,负责线程的创建、调度和销毁。 2. **任务队列**:线程池中存放待处理任务的...

    c++实现线程池

    线程池容器一般使用`std::vector`或`std::deque`来存储线程对象,任务队列则可以使用`std::queue`或者`std::priority_queue`。 2. **线程类**:每个线程需要负责从任务队列中取出任务并执行。这通常通过一个无限...

    c++经典线程池

    以下是一个简单的线程池实现框架: ```cpp #include #include &lt;vector&gt; #include #include #include class ThreadPool { public: ThreadPool(size_t numThreads); ~ThreadPool(); template, typename... ...

    简单linux C++线程池

    本教程将深入探讨如何在Linux环境下,使用C++实现一个简单的线程池。 首先,线程池的基本结构通常包括以下几个部分: 1. **线程池容器**:用于存储工作线程的集合,通常使用STL中的`std::vector`来实现。这个容器...

    c++ 线程池

    下面是一个简单的C++线程池实现示例: ```cpp #include #include &lt;vector&gt; #include #include #include class ThreadPool { public: ThreadPool(size_t numThreads) : stopped(false) { for (size_t i = 0; ...

    一个简单的c++ 线程池

    这个简单的C++线程池实现展示了如何在Linux环境下高效地管理和调度线程,通过使用线程池,我们可以更好地控制并发执行的任务数量,提高系统资源的利用率,并简化多线程编程的复杂性。理解并能应用这样的线程池设计,...

    C++的网络线程池实现

    下面是一个简单的C++线程池实现框架: ```cpp #include #include #include #include class ThreadPool { private: std::vector&lt;std::thread&gt; workers; std::queue()&gt;&gt; tasks; std::mutex queue_mutex; std...

    Java代码构建一个线程池

    本文将详细介绍如何使用Java语言来构建一个简单的线程池,并深入分析其实现原理与关键细节。 #### 一、线程池的概念 线程池是一种基于池化技术的设计模式,其核心思想是在程序启动时创建一定数量的线程放入池中供...

    C++11线程池 bcb

    以下是一个简单的线程池实现框架: 1. **线程池类定义**:首先定义一个线程池类,包含任务队列、线程集合、同步原语等成员变量。 2. **构造函数**:初始化线程池,创建一定数量的工作线程。 3. **提交任务**:提供...

    JAVA服务器端Socket线程池

    这是一个简单的线程池类定义,包含了线程池的基本属性和方法。 ##### 4.2 属性定义 ```java public static final int MAX_THREADS = 100; public static final int MAX_SPARE_THREADS = 50; public static final ...

    JAVA服务器端Socket线程池[借鉴].pdf

    在给定的代码示例中,`ThreadPool` 类是一个简单的线程池实现,它包含以下几个关键组件: 1. `pool`: 一个 `Vector` 对象,用于存储空闲线程。当线程完成任务后,它们会返回到池中,等待被重新分配新的任务。 2. `...

    Ubuntu/linux c开发(4)线程池

    本文将深入探讨线程池的概念、实现原理以及如何在Ubuntu/Linux环境下使用C++进行线程池的编程。 线程池的核心概念在于“池化”资源,即维护一组线程,这些线程处于待命状态,随时准备处理到来的任务。当有新的任务...

    C++线程池的简单实现方法

    总结来说,C++线程池的简单实现涉及线程的创建、管理以及同步机制的使用。理解这些基本概念和API是实现高效线程池的关键,而线程池的设计则需要考虑任务调度策略、资源管理以及线程间的通信问题。在实际项目中,可以...

    基于C++11的threadpool线程池(简洁且可以带任意多的参数)

    下面是一个简单的线程池实现: ```cpp class threadpool { using Task = std::function()&gt;; std::vector&lt;std::thread&gt; pool; // 线程池 std::queue&lt;Task&gt; tasks; // 任务队列 std::mutex m_lock; // 同步 std...

Global site tag (gtag.js) - Google Analytics