(一)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. 基本状态图


    4594948-de46975d9c55e169.png
    20011044-cffc02c7b77b49dfaf42ed611c8b1cf8.png

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

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


    4594948-2a2d69b1389f02ae.png
    20012411-7f68664925844134a8a416b63f808fe4.png

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

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


    4594948-743b4ea7190fd03e.png
    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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值