(一)java多线程(转)

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 又来到了一个老生常谈的问题,应用层软件开发的程序员要不要了解和深入学习操作系统呢? 今天就这个问题开始,来谈谈操...
    tangsl阅读 4,164评论 0 23
  • 本文主要讲了java中多线程的使用方法、线程同步、线程数据传递、线程状态及相应的一些线程函数用法、概述等。 首先讲...
    李欣阳阅读 2,482评论 1 15
  • Java多线程学习 [-] 一扩展javalangThread类 二实现javalangRunnable接口 三T...
    影驰阅读 2,986评论 1 18
  • 前言 多线程并发编程是Java编程中重要的一块内容,也是面试重点覆盖区域,所以学好多线程并发编程对我们来说极其重要...
    嘟爷MD阅读 7,334评论 21 272
  • 体验入 当家人智慧 ,能量通道,求路,没有人能让你成功,除非你把企业当家。 找核心 平台 转身用 看清楚路,对准方...
    Una笑笑阅读 414评论 0 1