标签:同步 Thread synchronized 甘源册 笔记 加锁 线程 2022 方法
目录知识点掌握情况
锁(了解) Object的多线程方法(了解)
学习心情
崩溃!!!
1.多线程
1.1锁
-
synchronized(多线程——重量级的锁)
-
JDK1.6对synchronized进行了优化,为了减少锁和释放锁带来的性能消耗引入的偏向锁和轻量级锁。
-
synchronized有三种方式来加锁,分别是:
- 修饰实例方法——作用于当前实例加锁,进入同步代码前要获得当前实例的锁
- 代码块——指定加锁对象,对给定对象加锁,进入同步代码块之前要获得给定对象的锁
- 修饰静态方法——作用于当前类对象加锁,进入同步代码之前要获得的是当前类对象的锁
-
三种方法的锁
- 实例方法:调用该方法的实例
- 静态方法:类对象
- this:代表该方法的实例对象
- 类对象:类对象
-
// 同步代码块 // 创建一个对象 // 类对象 // 当前实例this // 同步监视器 synchronized (Ch01.class){ }
-
操作共享数据的代码
- 共享数据:多个线程共同操作的变量,都可以充当锁
-
关于同步方法:
- 同步方法依然涉及到同步锁对象,不需要我们写出来
- 非静态的同步方法,同步锁就是this;静态的同步方法,同步监视器就是类本身
-
关于同步代码块
- 选好同步监视器(锁)推荐使用类对象,第三方对象,this
- 在实现接口创建的线程类中,同步代码块不可以用this来充当同步锁
-
同步方式,解决线程的安全问题,操作同步代码时,只有一个线程能够参与,其他线程等待,相当于一个单线程的过程,效率低。
-
synchronized只针对当前JVM可以解决的线程安全问题。
-
synchronized不可以跨JVM解决问题!!!
-
1.2死锁
- 死锁是多个线程同时被阻塞,他们中一个或多个都在等待某个资源的释放,由于线程无限期的阻塞,程序就不可能正常终止
- Java中死锁产生四个必要条件:
- 互斥使用:当资源被一个线程使用(占用),别的线程不能使用。
- 不可抢占:资源请求者不能强制从占有者中抢夺资源,资源只能从占有者手动释放。
- 请求和保持:
- 循环等待:存在一个等待的队列。例——P1占有了P2的资源,P2占有了P3的资源,P3占有了P1的资源。形成一个等待的环路。
1.3线程重入
- 任意线程在拿到锁之后,再次获取该锁不会被该锁所阻碍
- 线程不会被自己锁死的就叫——线程的重入, synchronized可重入锁
- JDK1.6锁的升级:
- 无锁:不加锁
- 偏内锁:不锁锁,只有一个线程争夺时,偏向某一个线程,这个线程不加锁
- 轻量级锁:少量线程来了之后,先尝试自旋,不挂起线程。
- 重量级锁:排队挂起(暂停)线程。
- 挂起线程和恢复线程需要转入内核状态中完成这些操作,给系统的并发性带来很大压力,在许多应用上共享数据的锁定状态,只会持续很短的时间,为了这段时间去挂起和恢复并不值得,我们可以让后面的线程等待一下,不要放弃处理器的执行时间。锁为了让线程等待,我们只需要让线程执行一个循环,——自旋。【自旋锁】
1.4Object类对多线程的支持
-
线程间的通信:两条线程,共同运行
-
wait(),wait(long timeout):当前线程进入等待状态
-
notify():唤醒正在等待的下一个线程
-
notifyAll():唤醒正在等待的所有线程
1.5方法总结:
-
Thread类的两个静态方法:
- sleep释放CPU资源,但是不会释放锁
- yield方法释放CPU执行权,保留CPU的执行资格,不常用。
-
Thread类的实例方法
- join方法,出让了执行权,join就加入进来。
-
Object类的方法
- wait方法:释放CPU资源,释放锁
- notify方法:唤醒等待中的线程
- notifyAll方法:唤醒等待中的所有线程
-
面试题——sleep和wait的区别
- 出处
- 锁的控制
-
案例:生产者与消费者模型化
1.6线程的退出
- 使用退出标志,线程正常退出,run方法结束后线程终止
- interrupt方法
- 中断线程:
1.7Thread类的常用方法
-
strat方法——启动当前线程:执行run方法。
-
run方法:什么也没有,只为重写
-
currentThread方法:静态方法,获取当前正在执行的线程
-
getID():返回此线程的唯一标识
-
getName(),setName():去设置和获取线程的name
-
getPriority:获取当前线程的优先级
-
setPriority:设置当前线程的优先级
-
getState:获取当前线程的状态
-
Thread thread = new Thread(); thread.start(); thread.interrupt(); try { Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println(thread.getState()); // TERMINATED
-
-
interrupt:中断线程的执行
-
isDaemon:测试当前线程是否是守护线程
1.8懒汉式单例模式
// 懒汉式最终版---过时,推荐内部类或者枚举(天生构造器私有化)
public class Ch03 {
private Ch03() {
}
private static Ch03 INSTANT;
public static Ch03 getInstance() {
if (INSTANT == null) {
synchronized (Ch03.class) {
if (INSTANT == null) {
INSTANT = new Ch03();
}
}
}
return INSTANT;
}
}
标签:同步,Thread,synchronized,甘源册,笔记,加锁,线程,2022,方法 来源: https://www.cnblogs.com/gycddd/p/16547654.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。