复习进程:
一.常见的进程切换的场景
1.有一个更高优先级的进程过来 ——抢占式OS
2.任务完成(进程结束)
3.每个进程都事先分配好了时间片,时间到达后会切换下一个进程
4.当进程在等待一个外部事件 ——阻塞
二.进程状态
就绪:进程处于可运行的状态,只是CPU时间片没有轮转到该进程,则该进程处于就绪状态;
运行:进程处于可运行的状态,且CPU时间片轮转到该进程,该进程正在执行代码,则该进程处于运行状态;
阻塞:进程不具备运行条件,正在等待某个事件的完成。
多线程:
1.什么是多线程?
答:将一个大任务分解成不同的小任务,交给不同执行流分别排队执行,就是多线程,哪个线程是主力,哪个就是主线程。
(可理解为:甲为一家公司办理业务,其中他要进行财务转账,福利发放和交社保,如果是他一人完成这件事,那么耗费的时间就特长,为了使业务更快的办理好,甲又叫来乙和丙,三个人分别负责一件事情,分别申请一个号码进行排队,于是就有了三个执行流共同完成任务,但本质上都为了办理一家公司的业务。乙和丙都是甲叫来的,所以甲一般被称为主线程。)
2.多进程和多线程最大的区别就是:是否有资源的共享
(多线程有资源的共享,多进程没有)
3.进程是资源分配的最小单位,线程是系统调度的最小单位,一个进程内的线程是可以共享资源的,每个进程至少有一个线程存在,即主线程。
——线程是轻量级进程
- 多线程的优势:
1>.在某些场景下,建模简单(代码好写)
2>.在某些场景下,运行速度可以提升
5.如何创建线程?
Thrad类 ——线程的描述(每个线程都有一个Thread类与之一一关联)
即演变成如何创建一个Thread对象???
1>.继承Thread类,覆写run方法
2>.实现Runnable接口的类,覆写run方法
6.Java中的内存区域:
栈:每个线程都有自己独立的栈空间,栈里的数据是不共享的;
堆:大家共享的是同一个堆和方法区;
方法区:堆和方法区中的数据是共享的。
7.JVM结束的条件,不是主线程退出就退出,而是所有非守护线程都退出才会退出(了解)
8.Thread类常用的属性
*.isAlive():线程只要处于不是NEW / TERMINATED状态就是活着的。
.yield():代码能执行,一定是取到了CPU资源,放弃这种资源回到队伍重新排队等候
(假设在同一个程序里用两个死循环分别打印张三和李四,在不调用.yield()方法的情况下,打印出的张三和李四基本是一样多的,但调用了“Thread.yield();”方法后,其中的一个会让出资源,致使自己被少打印,另外一个会被打印的多一点)
9.覆写Run方法是提供给线程要做的事情的清单,而调用start()方法,线程才真正独立的去执行
10.线程的缺点: 线程一旦开始执行,不完成是不会结束的,若中途有错误需要改正,停止线程之前需要很长的时间来反应。(调用Thread对象的interrupt()方法,会将对象的interrupt status置为true,是建议性的中断)
有两种方法可以解决:
1.通过共享的标记来进行沟通(不及时)
2.调用interrupt()方法来通知
在该篇可看到对比
- 如何中断线程?
1.通过自己控制自定义的状态(当B睡着的时候,只有等B醒来才可以看,通知的不够及时)
2.更合理的方法
interrupt() 通知
1>public boolean isInterrupted()
2>public static boolean Interrupted()
12.等待线程停止: *. join()
(若在多线程里,没有调用join()方法,其他的执行不会等到run()方法里的都执行完才执行main()方法里的,而是交叉执行,因为多线程是并行的)
*.join(mills:2000);//这个的意思是,等你等上2000毫秒,若你还没执行完,我就要开始执行
- 获取当前线程的Thread对象引用
Thread.currentThread();
14.休眠线程
Thread.sleep();
15.线程的状态,状态含义,相互转化,变化的原因:
1.什么是状态?(线程通过状态标识当前线程所处的一个情况)
答:JVM内部管理线程;提供给代码编写人员观察程序的运行情况的。
2.多线程有哪些状态?以及含义? Thread.State 枚举(Stste是枚举类型)
答:1>NEW:还没安排工作
2>RUNNABLE:已经准备好了,其中RUNNING是正在被CPU执行,READY是等着被服务
3>BLOCKED:做其他事情去了,
4>WAITING:等待一件事情干完
5>TIMED_WAITING:这件事情干完了再等一会再干下一件事情
6>TERMINATED:工作全部完成
16.线程安全:程序按照预期工作
线程不安全:程序没有按照预期正确工作
写程序:正确是底线,效率是追求
为甚么会出现线程不安全的问题???
答:1.栈里的数据是线程私有的,每个线程都有自己独立的调用栈
2.除了栈之外,其余的都是共享的![]()
对比: