zoukankan      html  css  js  c++  java
  • Java线程池

    1.什么是线程池

    线程池就是事先将多个线程放进一个容器中,当我们需要使用的时候不需要new一个而是去线程池中取一个。

    2.使用线程池的好处

    2.1不使用线程池的缺点(随用随创建的缺点)

    线程的创建和启动以及销毁的开销是巨大的。

    使用线程池可以在系统启动时就创建并启动线程,这样用户在请求时不会经历过多的线程创建和启动的时间,改善用户体验。

    2.2什么是线程

    线程是任务调度的基本单位。

    2.2.1Java线程的生命周期

     

    线程的五个状态:创建、就绪、运行、阻塞、消亡。

    a)       创建(new)

    当用new创建一个新的线程对象时,该线程处于创建状态。处于创建状态的线程对象是空的,系统不为它分配资源。

    b)       就绪(runnable)

    线程已经准备就绪,等待CPU为其分配资源。start()即就绪。

    c)       运行(running

    线程获得CPU资源,正在按顺序执行代码。

    d)       阻塞(blocked

    因sleep()或wait()或其他线程join()等而使线程暂停执行让出资源进入等待,即阻塞。

    sleep()时间结束或被唤醒nontify()或其他线程执行完毕,线程由阻塞状态进入就绪状态。

    e)       消亡(dead

    线程执行完毕,或被杀死,即进入消亡状态。

    2.2.2线程和进程的区别

    进程:是并发执行的程序在执行过程中分配和管理资源的基本单位,是一个动态概念,竞争计算机系统资源的基本单位。

    线程:是进程的一个执行单元,是进程内的调度实体。比进程更小的独立运行的基本单位。线程也被称为轻量级进程。

    进程是系统资源分配的基本单位,线程是任务调度的基本单位。

    开销:每个进程都有独立的代码和数据空间(程序上下文),程序之间的切换会有较大的开销;线程看做轻量级的进程,同一类线程共享代码和数据空间,每个线程都有独立的运行栈和程序计数器(PC),线程之间的切换开销小。

    所处环境:在操作系统中能同时运行多个进程(程序);而在同一个进程(程序)中有多个线程同时执行(通过CPU调度,在每个时间片中只有一个线程执行)

    内存分配方面:系统在运行的时候会为每个进程分配不同的内存空间;而对线程而言,除了CPU外,系统不会为线程分配内存(线程所使用的资源来自其所属进程的资源),线程组之间只能共享资源。

    包含关系:没有线程的进程可以看做是单线程的,如果一个进程内有多个线程,则执行过程不是一条线的,而是多条线(线程)共同完成的;线程是进程的一部分,所以线程也被称为轻权进程或者轻量级进程。

    3.线程池的类别

     

    运行线程:

    ExecutorService提供了submit和execute方法,向其传入runnable对象或FutureTask对象,当线程获得资源(时间片)时即可进入运行状态。

    关闭线程池;

    ExecutorService提供了shutdown方法可以关闭线程池。

  • 相关阅读:
    冒泡/快速排序
    Windows RT和WinRT
    UAC(User Access Control)操作小结(C++)
    将CHM文件转换为HTML文件
    WPF实现窗口比例恒定不变小结(2)
    用WinForm的ShowHelp()函数处理CHM文件
    Windows 8下对Microsoft Surface SDK 2.0的调查小结
    WPF实现窗口比例恒定不变小结(1)
    资源释放
    axis 1.4 使用及介绍
  • 原文地址:https://www.cnblogs.com/zhihow/p/9819898.html
Copyright © 2011-2022 走看看