(多)线程—Thread(一)

复习进程:

一.常见的进程切换的场景
1.有一个更高优先级的进程过来 ——抢占式OS
2.任务完成(进程结束)
3.每个进程都事先分配好了时间片,时间到达后会切换下一个进程
4.当进程在等待一个外部事件 ——阻塞
二.进程状态
在这里插入图片描述
就绪:进程处于可运行的状态,只是CPU时间片没有轮转到该进程,则该进程处于就绪状态;
运行:进程处于可运行的状态,且CPU时间片轮转到该进程,该进程正在执行代码,则该进程处于运行状态;
阻塞:进程不具备运行条件,正在等待某个事件的完成。

多线程:

1.什么是多线程?
答:将一个大任务分解成不同的小任务,交给不同执行流分别排队执行,就是多线程,哪个线程是主力,哪个就是主线程
(可理解为:甲为一家公司办理业务,其中他要进行财务转账,福利发放和交社保,如果是他一人完成这件事,那么耗费的时间就特长,为了使业务更快的办理好,甲又叫来乙和丙,三个人分别负责一件事情,分别申请一个号码进行排队,于是就有了三个执行流共同完成任务,但本质上都为了办理一家公司的业务。乙和丙都是甲叫来的,所以甲一般被称为主线程。)

2.多进程和多线程最大的区别就是:是否有资源的共享
(多线程有资源的共享,多进程没有)

3.进程是资源分配的最小单位,线程是系统调度的最小单位,一个进程内的线程是可以共享资源的,每个进程至少有一个线程存在,即主线程。
——线程是轻量级进程

  1. 多线程的优势:
    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. 如何中断线程?
    1.通过自己控制自定义的状态(当B睡着的时候,只有等B醒来才可以看,通知的不够及时)
    2.更合理的方法
    interrupt() 通知
    1>public boolean isInterrupted()
    2>public static boolean Interrupted()
    在这里插入图片描述

12.等待线程停止: *. join()
(若在多线程里,没有调用join()方法,其他的执行不会等到run()方法里的都执行完才执行main()方法里的,而是交叉执行,因为多线程是并行的)
*.join(mills:2000);//这个的意思是,等你等上2000毫秒,若你还没执行完,我就要开始执行

  1. 获取当前线程的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.除了栈之外,其余的都是共享的 在这里插入图片描述 在这里插入图片描述

对比:
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值