Day_21 多线程

本文详细介绍了Java中的多线程概念,包括程序、进程、线程的定义,以及并行和并发的区别。讨论了单核和多核CPU下多线程的执行情况,并探讨了多线程的优缺点和应用场景。接着,讲解了线程的创建方式,如Thread和Runnable,以及线程的优先级、控制、同步和锁机制。最后提到了定时器在多线程中的应用。
摘要由CSDN通过智能技术生成

1. 多线程

1.1 程序,进程,线程

程序 : 一组命令的集合,为了完成指定的功能,程序是静态概念,一般保存在硬盘当中

进程 : 正在运行的程序,是一个动态概念,需要保存在内存当中,操作系统会分配对应的PID,当我们直接关闭某个进程的时候,该进行会在运行内存中被销毁

线程 : 一个程序中,不同的执行分支,如果同一个时间节点允许多个线程同时执行的时候,我们称为支持多线程

在Java中,main方法开始执行,就是一个线程,称为主线程

1.2 并行和并发

并行 : 多个CPU,同时执行多个任务

并发 : 一个CPU,同时执行多个任务

多线程并行 必须CPU要大于等于2 才行,单核CPU是没有多线程的

1.3 单核CPU 和 多核CPU

单核CPU,其实是一种假的多线程,因为在一个时间单元内,也只能执行一个线程 的任务。例如:虽然有多车道,但是收费站只有一个工作人员在收费,只有收了费才能通过,那么CPU就好比收费人员。如果有某个人不想交钱,那么收费人员可以 把他“挂起”(晾着他,等他想通了,准备好了钱,再去收费)。但是因为CPU时间单元特别短,因此感觉不出来

如果是多核的话,才能更好的发挥多线程的效率

一个Java应用程序java.exe,其实至少有三个线程:main()主线程,gc() 垃圾回收线程,异常处理线程。当然如果发生异常,会影响主线程

1.4 多线程优缺点和应用场景

背景:以单核CPU为例,只使用单个线程先后完成多个任务(调用多个方 法),肯定比用多个线程来完成用的时间更短,为何仍需多线程呢?

多线程程序的优点:

  1. 提高应用程序的响应。对图形化界面更有意义,可增强用户体验。
  2. 提高计算机系统CPU的利用率
  3. 改善程序结构。将既长又复杂的进程分为多个线程,独立运行,利于理解和修改

程序需要同时执行两个或多个任务

程序需要实现一些需要等待的任务时,如用户输入、文件读写操作、网络操作、搜索等

需要一些后台运行的程序时

1.5 线程创建

1.5.1 Thread

第一种 : 创建一个类,继承Thread类,覆写run方法

 1.5.2 Runnable 

第二种,就是创建一个类,实现Runnable接口,并覆盖run方法

1.6 优先级

setPriority() : 设置优先级,Java中有1-10 ,10个优先级

getPriority() : 获取优先级等级

说明 :

线程创建时继承父线程的优先级

低优先级只是获得调度的概率低,并非一定是在高优先级线程之后才被调用

1.6.1 常用方法

创建线程对象

 设置名字

 设置优先级为10

 启动线程

  睡眠500毫秒

  获取线程对象并获取线程名字

 1.7 线程控制

1.7.1 线程停止 

stop : 终止否个线程执行,该方法已过时,不推荐使用,因为有可能导致死锁

所以一般使用标识符解决

 1.7.2 线程合并

join : 线程合并,让当前线程等待指定线程执行完,再继续执行

 1.7.3 yield

yield : 静态方法,暂停当前正在执行的线程对象,并执行其他等待中的线程

1 静态方法,意味着跟那个对象调用没有关系,写在哪个线程中,哪个线程就让位

2 给同优先级让位,不同优先级不让位

 1.8 线性同步

线程同步 : 当多个线程有可能同时操作同一个数据的时候,为了保证数据一致性,需要进行同步执行

本质是同步数据,是一种安全机制

异步编程 : 线程之间是完全独立的,相互没有影响

同步编程 : 线程之间不是完全独立的,相互可能有影响

同步的场景 : 1 必须是多线程(必须有并发性,才有可能出错) 2 多个线程有可能在同一时间操作同一个数据的可能性 3尤其是同时对数据进行更改操作,查询无所谓

 

 1.8.1 解决方法

方发锁 : 

 方法使用synchronized之后,该方法只能有一个线程执行

语句块锁 :

假如 该方法中,只有部分代码需要同步的时候,如果通过synchronized修饰,效率会大大折扣所以 我们可以通过语句块锁,只锁对应的代码,这样的话该方法中其他的代码还是可以同时执行,效率有所提升

 1.8.2  Synchronized

synchronized(对象){} 成员语句块锁

当访问一个对象中加锁的成员方法或者成员成员语句块锁的时候,则该对象中所有加锁的成员方法和成员语句块锁 全部锁定

synchronized(类名.class){} 静态语句块锁

当访问一个类中,加锁的静态方法或者静态语句块锁的时候,则该对象中所有加锁的静态方法和静态语句块锁 全部锁定

1.9 Lock

概述 :

 lock 是显示锁,需要手动开启和关闭  synchronized是隐式锁,自动开启,执行完自动关闭

lock只有代码块锁 , 而 synchronized支持方法和代码块锁

 lock锁,需要JVM花费较少的时间来进行资源调度.性能相对较好,而有很好的扩展性

使用顺序 : Lock锁 ---> 同步代码块锁 ---> 方法锁

1.10 定时器

定时器 : 计划任务

只要有一个计划任务,就会开启一个线程,进行计时,到达指定时间后,由该线程来完成这个任务

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值