首页 > 基础资料 博客日记

2022-08-02 第六组 Myy 学习笔记_Java_线程的控制方法

2023-08-09 18:54:02基础资料围观215

文章2022-08-02 第六组 Myy 学习笔记_Java_线程的控制方法分享给大家,欢迎收藏Java资料网,专注分享技术知识

 

线程的控制方法

synchronized多线程并发编程。重量级锁。

JDK1.6对synchronized进行了优化。

JDK1.6为了减少获得锁和释放锁带来的性能消耗引入的偏向锁和轻量级锁。

 

synchronized有三种方式来加锁,分别是:

(1)修饰实例方法,作用于当前实例加锁,进入同步代码前要获得当前实例的锁。

(2)静态方法,作用于当前类对象加锁,进入同步代码块前要获得的当前类对象的锁。

(3)代码块,指定加锁对象,对给定的对象加锁,进入同步代码块前要获得给定对象的锁。

 

xx的锁对象

(1)实例对象:调用该方法的实例

(2)静态方法:类对象

(3)this:调用该方法的实例对象

(4)类对象:类对象

 

操作共享数据的代码

共享数据 -> 多个线程共同操作的变量,都可以充当。

 

当使用同步方法时,synchronized锁的东西是this(默认的)。实现接口和继承类不一样

 

关于同步方法:

1)同步方法依然涉及到同步锁对象,不需要我们写出来

2)非静态的同步方法,同步锁就是this

静态的同步方法,同步监视器就是类本身

 

同步代码块:

1)选好同步监视器(锁),推荐使用类对象,第三方对象,this

2)在实现接口创建的线程类中,同步代码块不可以用this来充当同步锁。

 

同步的方式,解决线程安全的问题。

操作同步代码时,只有一个线程能够参与,其他线程等待。

相当于一个单线程的过程,效率低。

 

synchronized只针对于当前的JVM可以解决线程安全问题。

synchronized不可以跨JVM解决问题!

 

死锁

死锁是这样一种情形:多个线程同时被阻塞,他们中的一个或者全部都在等待某个资源的释放,由于线程无限期的阻塞,程序就不可能正常终止。

 

Java中死锁产生四个必要条件

1.互斥使用,当资源被一个线程使用(占用),别的线程不能使用。

2.不可抢占,资源请求者不能强制从占有者中抢夺资源,资源只能从占有者手动释放。

3.请求和保持,

4.循环等待,存在一个等待队列。P1占有P2的资源,P2占有P3的资源,P3占有P1的资源。形成了一个等待环路。

 

线程重入

任意线程在拿到锁之后,再次获取该锁不会被该锁所阻碍。

 

线程是不会被自己锁死的。这就叫线程的重入,synchronized可重入锁。

 

JDK1.6以后锁升级:

1.无锁:不加锁

2.偏向锁:不锁锁,当只有一个线程争夺时,偏向某一个线程,这个线程不加锁。

3.轻量级锁:少量线程来了之后,先尝试自旋,不挂起线程。

4.重量级锁:排队挂起线程(挂起可理解为暂停)synchronized。

 

挂起线程和恢复线程需要转入内核态中完成这些操作,给系统的并发性带来很大的压力。

在许多应用上共享数据的锁定状态,只会持续很短的时间,为了这段时间去挂起和恢复并不值得。

我们可以让后面的线程等待一下,不要放弃处理器的执行时间。锁为了让线程等待,我们只需要让线程执行一个循环,自旋(自旋锁

 

hashcode值 1 0

 

Object类对多线程的支持

wait():

wait(long timeout):当前线程进入等待状态

notify():唤醒正在等待的下一个进程

notifyAll():唤醒正在等待的所有进程

 

线程间的通信

比如两条线程,共同运行。

线程A如果先走,线程B就要等待。等待线程A先走,唤醒线程B,线程B再走。

 

方法的总结:

1.Thread的两个静态方法

- sleep释放CPU资源,但是不会释放锁

- yield方法释放CPU执行权,保留了CPU的执行资格,不常用

2.join方法,yield插队(不是静态方法),出让了执行权,join就加入进来。

3.wait:释放CPU资源,释放锁

notify:唤醒等待中的线程

notifyAll:唤醒等待中的所有线程

 

面试题:sleep和wait的区别?

1.出处

2.锁的控制

 

案例:生产者与消费者模型

两条线程,一条线程生产产品,另一条线程消费产品。

思路:这两条线程,初始状态是什么情况?

电脑工厂,生产电脑是需要时间。生产完毕100台电脑。

唤醒这些等待的消费者,等待。唤醒工厂,继续生产。

消费者,等待,被唤醒,100台电脑被卖出去了,等待。

 

线程的退出

使用退出标志,线程正常退出,run方法结束后线程终止。不要使用stop方法。

interrupt方法 -- 中断线程。

调用interrupt方法会抛出InterruptedException异常,捕获后再做停止线程的逻辑即可。

如果是线程while(true)运行的状态,interrupt方法无法中断线程。

 

线程的常用方法:

Thread类中的方法

1.start:启动当前线程;执行run方法

2.run:

3.currentThread:静态方法,获取当前正在执行的线程。

4.getId():返回此线程的唯一标识

5.setName():设置当前线程的name

6.getName():获取当前线程的name

7.getPriority():获取当前线程的优先级

8.setPriority(int):设置当前线程的优先级

9.getState():获取当前线程的生命周期

10.interrupt():中断线程的执行

11.interrupt():测试当前线程是否中断

 

单例模式-懒汉式

饿汉式性能低,安全性高

懒汉式:过时

内部类,枚举(天生构造器私有化)

Callable接口:抛异常

run方法:不能抛异常


文章来源:https://www.cnblogs.com/JNMyy/p/16548877.html
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:jacktools123@163.com进行投诉反馈,一经查实,立即删除!

标签:

相关文章

本站推荐

标签云