`
hongzhguan
  • 浏览: 272750 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

java线程池举例详解

阅读更多

进程是程序的一个动态执行过程,是指一个内存中运行的应用程序,每个进程都有自己独立的一块内存空间,一个进程中可以启动多个线程。比如在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....

    Java面试 spring知识点 线程池 面试题

    在Java面试中,Spring框架是不可或缺的知识点,尤其在涉及到线程池的面试题时,对Spring的理解深度往往成为衡量候选人技术能力的重要标准。本文将深入探讨Spring框架的核心原理、重要概念以及与线程池相关的知识。 ...

    java 浮点数举例

    java 浮点数举例java 浮点数举例java 浮点数举例

    JAVA多态图文详解ppt

    JAVA多态图文详解ppt,详细通过各种举例介绍JAVA多态的ppt

    java常用API举例

    Java API,全称为Java应用程序接口,是Java编程语言的核心组成部分,包含了各种类库、接口和异常,为开发者提供了丰富的功能,极大地提高了开发效率。本文将深入探讨Java API中的一些常见且重要的类和方法,结合实际...

    概括设计模式,举例详解抽象工厂模式

    这种模式在资源管理、配置管理和线程池等场景下非常有用,因为它可以确保系统中只存在一份资源或配置的唯一实例,避免了资源冲突和浪费。 #### 结构型模式 结构型模式关注如何将类或对象结合在一起形成更大的结构...

    JAVA实验举例和事例

    根据提供的文件信息,我们可以推断出这是一篇关于Java编程语言的文章,主要目的是通过具体的例子帮助初学者更好地理解和...以上就是关于“Java实验举例和事例”的详细介绍,希望能够帮助到正在学习Java编程的初学者们。

    JAVA常用设计模式详解大全

    该文件里面包含JAVA开发常用的设计模式,通过举例、分析、代码示意的方式让读者很容易理解

    java词法分析举例

    总结起来,这个"java词法分析举例"是一个实践性的教学资源,帮助开发者深入理解Java源代码是如何被分解成可操作的单元,为后续的语法分析和代码生成奠定基础。通过这个例子,你可以学习到如何定义和实现词法规则,...

    NP完全问题详解,举例详解

    本文档对NP完全问题详细解释,举了很多的例子 NP完全问题(NP-C问题),是世界七大数学难题之一。 NP的英文全称是Non-deterministic Polynomial的问题,即多项式复杂程度的非确定性问题。简单的写法是 NP=P?...

    Java正则表达式详解

    举例说明: - 社会安全号码的匹配:例如“\d{3}-\d{2}-\d{4}”匹配999-99-9999格式,如果允许省略连字符,可以变为“\d{3}-?\d{2}-?\d{4}”。 - 汽车牌照号:如“\d{4}[A-Z]{2}”匹配四位数字后接两位大写字母的格式...

    Java正则表达式详解.doc

    举例来说,如果你想要在Java中验证一个美国社会安全号码,可以编写如下代码: ```java import java.util.regex.*; public class Main { public static void main(String[] args) { String ssn = "123-45-6789"; ...

    JAVA实验典型举例

    "JAVA实验典型举例"这个资源提供了一系列的Java实例,旨在帮助学习者深入理解和应用Java的核心概念。通过分析这些代码,我们可以强化理论知识,提高解决问题的能力。 首先,Java是一种面向对象的编程语言,它的主要...

    javahibernate应用举例

    在这个“javahibernate应用举例”中,我们将深入探讨如何利用Hibernate简化Java中的SQL操作,以及如何实现数据的查找和保存功能。 首先,Hibernate通过提供一个API,使得开发人员无需直接编写SQL语句就能进行数据...

    Java设计模式举例原码

    对23中设计模式进行了详细的举例介绍。欢迎你的加入Java设计模式学习。 作者介绍: Rohit Joshi works as a Software Engineer in the Consumer Product Sector. He is a Sun Certified Java Programmer. He had ...

    java垃圾回收器代码举例

    Java垃圾回收器(Garbage Collector, GC)是Java编程语言中的一个重要特性,它负责自动管理内存,自动回收不再使用的对象,以防止内存泄漏。在Java中,程序员无需手动释放内存,这一过程由JVM(Java虚拟机)自动完成...

    动态规划问题举例详解

    本文档对动态规划问题详细解释,举例很多,使初学者容易理解,绝对物超所值,希望大家下载观看 动态规划一般可分为线性动规,区域动规,树形动规,背包动规四类。

    mpeg2-ps流结构举例详解

    ### MPEG2-PS流结构详解 #### 一、概述 MPEG-2标准不仅定义了音视频编码方式,还规定了这些数据如何被组织成文件结构。PS(Program Stream)流是MPEG-2标准中一种重要的封装格式,主要用于存储和传输连续媒体数据,...

    Java多线程技术详解

    Java多线程技术详解 在计算机编程中,多线程是一种重要的并发处理机制,它允许多个任务在同一个程序中并行执行。Java作为一种强健的面向对象的编程语言,提供了丰富的多线程支持,使得开发者能够高效地利用系统资源...

Global site tag (gtag.js) - Google Analytics