进程是程序的一个动态执行过程,是指一个内存中运行的应用程序,每个进程都有自己独立的一块内存空间,一个进程中可以启动多个线程。比如在Windows
系统中,一个运行的exe就是一个进程。线程是指进程中的一个执行流程,一个进程中可以运行多个线程。比如java.exe进程中可以运行很多线程。线程
总是属于某个进程,进程中的多个线程共享进程的内存。“同时”执行是人的感觉,在线程之间实际上轮换执行。
实现多线程有两种手段,一种是集成Thread类,另一种就是实现Runnable接口。
在CPU和内存还有磁盘IO并没有充分利用的时候,就可以在重构的时候,使用线程操作,将过去需要占用一定时间的同步操作,进行并发处理。这样,创建多个线程来解决同一个问题。这样就可以使操作成为异步,不需要进行等待就可以同时操作很多事情。
那么线程需要创建多少呢?
每监听到一个请求就创建一个线程,然后操作之后就销毁。这种办法可行么?
如果突然在客户端提交了1000000
* N
个请求,这些请求都进入服务器,然后在这里,为每一个请求都创建一个线程来执行。这样程序就会失去控制。最终挤爆服务器CPU和内存,使程序崩溃。
怎么样合理、可控的处理操作,变成了重点。
线程池,顾名思义,在池化开发的现在,如数据库连接池这种开发模式已经广泛流行。
在池中创建连接实例,在访问数据库时,从连接池中取得连接,操作之后归还。这样就可以有效的限制资源数量,但是又能提高操作速度。
package test.dao;
import java.util.LinkedList;
import org.apache.log4j.Logger;
public class ThreadPool {
private static final Logger Log = Logger.getLogger(ThreadPool.class);
private ThreadWorker[] worker;
private LinkedList<Runnable> queue;
private int poolSize;
public int getPoolSize(){
return poolSize;
}
//initialize thread pool with pool size
public ThreadPool(int size){
poolSize = size;
worker = new ThreadWorker[size];
queue = new LinkedList<Runnable>();
for (int i = 0; i < size; i++) {
worker[i] = new ThreadWorker();
worker[i].start();
}
}
//add work queue
public void addQueue(Runnable runnable){
synchronized(queue) {
queue.add(runnable);
queue.notify();
}
}
//worker do work
private class ThreadWorker extends Thread{
public void run(){
//runnable
Runnable runable;
while (true) {
synchronized(queue) {
while (queue.isEmpty()) {
try
{
//is work queue is empty, wait
queue.wait();
}
catch (Exception e)
{
Log.error("pool queue wait", e);
}
}
//get work in queue, and remove it
runable = queue.removeFirst();
}
try {
//do work
runable.run();
}
catch (RuntimeException e) {
Log.error("unknow runtime exception", e);
}
}
}
}
public static void main(String[] args) {
//test
ThreadPool pool = new ThreadPool(111);
//
class SSS implements Runnable{
private String abc;
public void setAbc(String aaaaa){
this.abc = aaaaa;
}
public void run() {
System.out.println("do runnable " + abc);
}
}
for (int i = 0; i < 200; i++) {
SSS a = new SSS();
a.setAbc(String.valueOf(i + 1));
pool.addQueue(a);
}
}
}
分享到:
相关推荐
Java线程池是一种高效管理并发任务的机制,它通过复用已存在的线程来减少线程创建和销毁的开销,从而提高系统的整体性能。本文将深入解析Java线程池的工作原理,并给出创建简单实例的步骤。 线程池的核心在于`java....
在Java面试中,Spring框架是不可或缺的知识点,尤其在涉及到线程池的面试题时,对Spring的理解深度往往成为衡量候选人技术能力的重要标准。本文将深入探讨Spring框架的核心原理、重要概念以及与线程池相关的知识。 ...
Java 课程设计举例
java 浮点数举例java 浮点数举例java 浮点数举例
JAVA多态图文详解ppt,详细通过各种举例介绍JAVA多态的ppt
Java API,全称为Java应用程序接口,是Java编程语言的核心组成部分,包含了各种类库、接口和异常,为开发者提供了丰富的功能,极大地提高了开发效率。本文将深入探讨Java API中的一些常见且重要的类和方法,结合实际...
这种模式在资源管理、配置管理和线程池等场景下非常有用,因为它可以确保系统中只存在一份资源或配置的唯一实例,避免了资源冲突和浪费。 #### 结构型模式 结构型模式关注如何将类或对象结合在一起形成更大的结构...
根据提供的文件信息,我们可以推断出这是一篇关于Java编程语言的文章,主要目的是通过具体的例子帮助初学者更好地理解和...以上就是关于“Java实验举例和事例”的详细介绍,希望能够帮助到正在学习Java编程的初学者们。
该文件里面包含JAVA开发常用的设计模式,通过举例、分析、代码示意的方式让读者很容易理解
总结起来,这个"java词法分析举例"是一个实践性的教学资源,帮助开发者深入理解Java源代码是如何被分解成可操作的单元,为后续的语法分析和代码生成奠定基础。通过这个例子,你可以学习到如何定义和实现词法规则,...
本文档对NP完全问题详细解释,举了很多的例子 NP完全问题(NP-C问题),是世界七大数学难题之一。 NP的英文全称是Non-deterministic Polynomial的问题,即多项式复杂程度的非确定性问题。简单的写法是 NP=P?...
举例说明: - 社会安全号码的匹配:例如“\d{3}-\d{2}-\d{4}”匹配999-99-9999格式,如果允许省略连字符,可以变为“\d{3}-?\d{2}-?\d{4}”。 - 汽车牌照号:如“\d{4}[A-Z]{2}”匹配四位数字后接两位大写字母的格式...
举例来说,如果你想要在Java中验证一个美国社会安全号码,可以编写如下代码: ```java import java.util.regex.*; public class Main { public static void main(String[] args) { String ssn = "123-45-6789"; ...
"JAVA实验典型举例"这个资源提供了一系列的Java实例,旨在帮助学习者深入理解和应用Java的核心概念。通过分析这些代码,我们可以强化理论知识,提高解决问题的能力。 首先,Java是一种面向对象的编程语言,它的主要...
在这个“javahibernate应用举例”中,我们将深入探讨如何利用Hibernate简化Java中的SQL操作,以及如何实现数据的查找和保存功能。 首先,Hibernate通过提供一个API,使得开发人员无需直接编写SQL语句就能进行数据...
对23中设计模式进行了详细的举例介绍。欢迎你的加入Java设计模式学习。 作者介绍: Rohit Joshi works as a Software Engineer in the Consumer Product Sector. He is a Sun Certified Java Programmer. He had ...
Java垃圾回收器(Garbage Collector, GC)是Java编程语言中的一个重要特性,它负责自动管理内存,自动回收不再使用的对象,以防止内存泄漏。在Java中,程序员无需手动释放内存,这一过程由JVM(Java虚拟机)自动完成...
本文档对动态规划问题详细解释,举例很多,使初学者容易理解,绝对物超所值,希望大家下载观看 动态规划一般可分为线性动规,区域动规,树形动规,背包动规四类。
### MPEG2-PS流结构详解 #### 一、概述 MPEG-2标准不仅定义了音视频编码方式,还规定了这些数据如何被组织成文件结构。PS(Program Stream)流是MPEG-2标准中一种重要的封装格式,主要用于存储和传输连续媒体数据,...