20165308第八周学习总结
20165308第八周学习总结
课本知识点总结
- 进程:代码加载、执行、执行完毕(共享操作系统资源)
- 线程:一个进程由多个线程组成。(共享进程中某些内存单元,例如代码与数据)
- 关系:线程是运行在进程中的小线程。
- 多线程:几个执行体共同执行程序的过程。
- 多线程使用轮流执行机制
- 1个cpu只能同时执行一个线程。
- 主线程:JVM加载代码时,发现main方法之后启动的线程
- 线程的状态:
- 新建:Thread类或其子类的对象被声明并创建
- 运行:调用start()方法通知JVM;如果线程是Thread的子类创建的,程序必须在子类中重写run()方法
- 中断:
- JVM讲CPU切换给其他线程
- 执行sleep(int millsecond)方法,等待millsecond指定时间后,重新排队等待
- 执行wait()必须由线程调用notifyll方法,才能重新排队
- 进入阻塞状态
- 死亡:释放分配给线程的内存
- 正常死亡,运行完run()
- 被提前强制终止
- 线程的创建
- 使用Thread类子类创建:需要重写run()方法。
- 使用Thread类
- 构造方法:Thread(Runable target)
- 需要创建一个Runnable接口类的事例,并在该接口中重写run方法。
- 目标对象与线程的关系:完全解耦和目标对象组合线程
- 线程的常用方法:
start()
: 线程调用该方法将启动线程,使之从新建状态进入就绪队列排队,一旦轮到它来享用CPU资源时,就可以脱离创建它的线程独立开始自己的生命周期了。run()
: Thread类的run()方法与Runnable接口中的run()方法的功能和作用相同,都用来定义线程对象被调度之后所执行的操作,都是系统自动调用而用户程序不得引用的方法。sleep(int millsecond)
: 优先级高的线程可以在它的run()方法中调用sleep方法来使自己放弃CPU资源,休眠一段时间。isAlive()
: 线程处于“新建”状态时,线程调用isAlive()方法返回false。在线程的run()方法结束之前,即没有进入死亡状态之前,线程调用isAlive()方法返回true.currentThread()
:该方法是Thread类中的类方法,可以用类名调用,该方法返回当前正在使用CPU资源的线程。interrupt()
:一个占有CPU资源的线程可以让休眠的线程调用interrupt()方法“吵醒”自己,即导致休眠的线程发生InterruptedException异常,从而结束休眠,重新排队等待CPU资源。
- 线程同步 : 若干个线程都需要使用一个synchronized(同步)修饰的方法
- 线程同步机制
- 当一个线程使用
synchronized
方法时,其他线程若想使用就必须使用wait()
方法等待,直到该线程使用完该方法 - 其他线程在使用同步方法时若不需要等待,则用完方法的同时,执行
notifyAll()
方法通知所有处于等待状态的线程结束等待
必须要在同步方法中使用wait()、notify()、notifyAll()方法 - 线程联合
join()
:其他线程调用该方法,可以和正在使用CPU资源的线程联合。 - GUI线程
- 计时器线程:使用Time类
- 守护线程:使用
void setDaemon(boolean on)
方法
码云链接
https://gitee.com/BESTI-IS-JAVA-2018/5308/tree/master/src/ch12