美文网首页java技术
(一)java多线程(转)

(一)java多线程(转)

作者: 二月夜 | 来源:发表于2017-04-27 18:15 被阅读6次

1、线程概念

  • 进程:系统进行资源分配和调用的独立单位。每一个进程都有它自己的内存空间和系统资源(cpu、内存等)。
  • 线程:进程中的一段代码,一个进程中可以有多段代码。本身不拥有资源(共享所在进程的资源)
    1. 在同一个进程内又可以执行多个任务,而每一个任务我们就可以看成是一个线程。
    2. 是程序的执行单元,执行路径。是程序使用CPU的最基本的单位。
    • 如果程序只有一条执行路径,那么该程序就是单线程程序。
    • 如果程序有多条执行路径,那么该程序就是多线程程序。

2、多线程意义

  1. 多线程的存在,不是提高程序的执行速度。其实是为了提高应用程序的使用率。
  2. 程序的执行其实都是在抢CPU的资源,CPU的执行权。
  3. 多个进程是在抢这个资源,而其中的某一个进程如果执行路径比较多,就会有更高的几率抢到CPU的执行权。
  4. 我们是不敢保证哪一个线程能够在哪个时刻抢到,所以线程的执行有随机性。

3、并行和并发

  • 并行是逻辑上同时发生,指在某一个时间内同时运行多个程序。
  • 并发是物理上同时发生,指在某一个时间点同时运行多个程序

4、Java运行原理

java命令会启动java虚拟机,启动JVM,等于启动了一个应用程序,也就是启动了一个进程。该进程会自动启动一个“主线程”,然后主线程去调用某个类的main方法。所以main方法运行在主线程中。在此之前的所有程序都是单线程。
** jvm虚拟机至少启动了垃圾回收线程和主线程(调用main方法),所以是多线程的垃圾回收是以防出现内存溢出。**
C/C++可以去调用系统功能并创建进程,然后由Java去调用,实现多线程程序(Java不可以直接调用系统功能)

5、线程生命周期

  1. 基本状态图


    20011044-cffc02c7b77b49dfaf42ed611c8b1cf8.png

    图中是线程运行的基本状态:线程调用start()方法开始后,就进入到可运行状态,随着CPU的资源调度在运行和可运行之间切换;遇到阻塞则进入阻塞状态。

  2. 加入同步的线程状态图


    20012411-7f68664925844134a8a416b63f808fe4.png

    当资源被一个线程访问时,上锁,其他线程就进入了一个锁池(Lock pool);
    当锁被释放,其他线程获得了锁,就变为可运行状态。

  3. 加入线程间的相互作用


    20012759-f5110611bb224169a3eee61e2ffa77e0.png
  • 线程间的相互作用:
    • 主要是wait和notify方法的介绍。
    • 具有wait()和notify()的线程状态图:
  • 线程调用了wait()方法之后,释放掉锁,进入等待池(Wait pool) ;收到通知之后等待获取锁,获取锁之后才可以运行。
  1. 综上所述:(线程被阻塞可能是由于下面五方面的原因):
  2. 调用sleep(毫秒数),使线程进入睡眠状态。在规定时间内,这个线程是不会运行的。
  3. 用suspend()暂停了线程的执行。除非收到resume()消息,否则不会返回“可运行”状态。
  4. 用wait()暂停了线程的执行。除非线程收到notify()或notifyAll()消息,否则不会变成“可运行”状态。
  5. 线程正在等候一些IO操作完成。
  6. 线程试图调用另一个对象的“同步”方法,但那个对象处于锁定状态,暂时无法使用。

6、线程调度(两种)以及设置线程优先级:

  1. 分时调度模型。所有线程轮流使用CPU的使用权,平均分配每个线程占用CPU的时间片
  2. 抢占式调度模型。优先让优先级高的线程使用CPU,若相同,则随机选择,优先级高的线程获取CPU的时间片相对多一些。Java使用的是抢占式调度模型。
    设置线程优先级:
    public final int getPriority(); //返回线程对象的优先级。默认优先级是5。
    public final void setPriority(); //设置线程的优先级。
    MAX_PRIORITY最大优先级值是10
    MIN_PRIORITY最小优先级是1
    NORM_PRIORITY默认优先级是5

7、 线程控制

父类(Thread)方法:
- a. 线程休眠
public static void sleep(long millis);
//指定毫秒内休眠
//自定义类中run()里调用 Thread.sleep(millis);
// 进入阻塞状态,但是不释放资源,容易造成死锁
b.线程加入
public final void join();
//等待该线程终止,其他线程再开始
//主类中调用
c.线程礼让
public static void yield();
//暂停当前正在执行的线程对象,并执行其他线程
//自定义类中调用
//让多个线程的执行更和谐,但不能保证一个线程一次。
//释放资源(CPU、内存等),线程重新进入【就绪】状态,让相同优先级或者高优先级线程执行
d.后台线程
public final void setDaemon(boolean on);
//将该线程标记为守护线程或用户线程,当正在运行的线程都是守护线程时(即主线程灭亡,守护线程随之消失),Java虚拟机退出
//该方法必须在启动线程前调用
//主类中调用
e.中断线程
public final void stop();
//该方法已过时,但还可以使用。不建议使用,显示stop();
//多长时间线程没有进行就结束了
//主类中调用
public void interrupt();
//把线程的状态终止,抛出异常InterruptedException

相关文章

  • 2018-07-26 CountDownLatch

    【转】Java多线程系列--“JUC锁”09之 CountDownLatch原理和示例

  • (一)java多线程(转)

    1、线程概念 进程:系统进行资源分配和调用的独立单位。每一个进程都有它自己的内存空间和系统资源(cpu、内存等)。...

  • 带你搞懂Java多线程(五)

    带你搞懂Java多线程(一)带你搞懂Java多线程(二)带你搞懂Java多线程(三)带你搞懂Java多线程(四) ...

  • 带你搞懂Java多线程(六)

    带你搞懂Java多线程(一)带你搞懂Java多线程(二)带你搞懂Java多线程(三)带你搞懂Java多线程(四)带...

  • Java多线程目录

    Java多线程目录 Java多线程1 线程基础Java多线程2 多个线程之间共享数据Java多线程3 原子性操作类...

  • java多线程--Callable

    **移步[java多线程系列文章]Java多线程(二十二)---LockSupport工具Java 停止线程 一、...

  • android 多线程 — 线程的面试题和答案

    这里都是我从各个地方找来的资料,鸣谢: Java多线程干货系列—(一)Java多线程基础 JAVA多线程和并发基础...

  • 带你搞懂Java多线程(四)

    带你搞懂Java多线程(一)带你搞懂Java多线程(二)带你搞懂Java多线程(三) 什么是线程间的协作 线程之间...

  • Java多线程高级特性(JDK8)

    [TOC] 一、Java多线程 1.Java多线程基础知识 Java 给多线程编程提供了内置的支持。一条线程指的是...

  • Java多线程编程核心技术【笔记】

    Java多线程编程核心技术【笔记】 第一章 Java多线程技能 使用多线程的场景? 阻塞 多线程提高运行效率 依赖...

网友评论

    本文标题:(一)java多线程(转)

    本文链接:https://www.haomeiwen.com/subject/nhfnzttx.html