Java学习笔记-线程

线程
实现多线程
1.进程
是正在进行的程序,是系统进行资源分配和调用的独立单位。每一个进程都有它自己的内存空间和系统资源。
2.线程
是进程中的单个顺序控制流,是一条执行路径。
单线程:一个进程如果只有一条执行路径,则称为单线程程序。
多线程:一个进程如果有多条执行路径,则称为多线程程序。
3.多线程的实现方式
方式1:继承Thread类。
run()是用来封装被线程执行的代码;

run()方法和start()方法的区别
run()封装线程执行的代码,直接调用,想当与普通方法的调用。
start()启动线程;然后由JVM调用此线程的run()方法。
4.设置和获取线程名称
setName(String name),将此线程的名称更改为等于参数name
String getName();返回此线程的名称;
5.线程调度
两种线程调度模式:
1.分时调度模型:所有线程轮流使用CPU的使用权,平均分配每个线程占用CPU的时间片。
2.抢占式调度模型:优先让优先级高的线程使用CPU,如果线程的优先级相同,那么会随机选择一优先级别高的线程获得的CPU时间片相对多一些。

多线程程序的执行是有随机性的,因为谁抢到CPU的使用权是不一定的。

public final int getPriority();返回此线程的优先级。
public final void setPriority(int newPriority):更改次线程的优先级别
线程默认优先级是5;线程优先级的范围是1-10;
线程优先级别高仅仅表示线程获取的CPU时间片的几率更高,但是要在次数比较多,或者多次运行的时候才能看到你想要的的结果。
6.线程控制
在这里插入图片描述
7.线程的生命周期
在这里插入图片描述
线程同步
数据安全问题
出现的条件:
1.是否是多线程环境
2.是否有共享数据;
3.是否有多条语句操作共享数据。

解决方法:基本思想,让程序没有安全问题的环境。

实现方法:把多条语句操作共享数据的代码给锁起来,让任意时刻只能有一个线程执行即可。
同步代码块
格式
synchronized(任意对象){

}
弊端:当线程很多的时候,因为每个线程都会去判断同步上的锁,这是很耗费资源的,无形之中会降低程序的运行效率。
同步方法
将synchronized关键字加到方法上。
格式
修饰符 synchronized 返回值类型 方法名(参数){}
同步方法的锁对象是this。(非静态对象)
同步静态方法的锁对象是类名.class
线程安全类
StringBuffer 支持所有相同的操作,但它更快,因为他不执行同步。
Vector 被同步。(不常用)被Collections.synchronizedList(new ArrayList<>());代替
HashTable 被同步(不常用)
Lock锁
在这里插入图片描述
生产者与消费者
生产者线程用于产生数据
消费者线程用于消耗数据
同时中间还会存在一个共享数据区域
生产者生产的数据直接放在共享数据区中,不用关心消费者的行为
消费者只需要从共享数据区中获取数据,不需要关心生产者的行为。
在这里插入图片描述
Object类的等待和唤醒方法
在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值