2022-08-03 第七小组 房雪莹 学习笔记

今日学习内容:

1.锁:
 synchronized多线程并发编程
    重量级锁
   JDK1.6为了减少获得锁和释放锁带来的性能消耗引入的偏锁和轻量级锁
   synchronized有三种方式来加锁,分别是
   1)修饰实例的方法,作用于当前实例加锁,进入同步代码前要获得当前实例的锁
   2)静态方法,作用于当前类对象加锁,进入同步代码前要获得的当前类对象的锁
   3)代码块,指定加锁对象,对给定的对象加锁,进入同步代码块之前要获得给定对象的锁、

2.实例方法:(它的锁)调用该方法的实例
静态方法:类对象(.class)
this:调用该方法的实例对象
类对象:类对象

其实就是操作共享数据的代码
共享数据,多个线程共同操作的变量,都可以充当锁

当前使用同步方法时,synchronized锁的东西就是this当前对象

3.关于同步方法:
1.同步方法依然涉及到同步锁对象,不需要我们写出来
2.非静态的同步方法,同步锁就是this
  静态的同步方法,同步监视就是类本身

4.同步代码块:
1.选好同步监视器(锁)推荐使用类对象,第三方对象,this
2.在实现接口创建线程类中,同步代码块不可以用this来充当同步锁

同步的方法,解决了线程安全的问题
操作同步代码时,只有一个线程能够参与,其他线程等待
相当于一个单线程的过程,效率低。

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

6.java死锁产生的四个必要条件
1.互斥使用,当资源被一个线程使用,别的线程不能使用
2.不能抢占,资源的请求者不能强制从占用者中抢夺资源,资源只能从占有者手动释放
3.请求和保持
4.循环等待,存在一个等待队列,P1占有P2资源,P2占用P3的资源
  P3占有P1的资源。形成了一个等待环路

7.线程重入
任意线程在拿到锁之后,再次获取该锁不会被该锁所阻碍
线程不会被自己锁死的,这就叫线程重入,synchronized可重入锁

8.Object类对多线程的支持
wait():
wait(Long timeout):当前线程进入等待状态
notify():唤醒正在等待的下一个线程
notifyALL():唤醒正在等待的所有线程

9.线程的通信
比如两条线程,共同运行。
线程A 如果先走,线程B就要等待,等A走完,唤醒B,B再走

10.方法的总结:
1.Thread的两个静态方法:
 sleep释放CPU资源,但不会释放锁
 yield方法,释放CPU 的执行权,保留了CPU的执行资格(不常用)
 
2.join方法:yield出让了执行权,join就加入进来
3.wait方法:释放CPU资源,释放锁
  notify:唤醒正在等待的下一个线程
  notifyALL:唤醒正在等待的所有线程

11.线程的退出
使用退出标志,线程正常退出,run方法结束后线程终止
不要使用stop方法,System.exit(-1)

12.线程的常用方法:
Thread类中的方法
1.start方法:启动当前线程,执行run方法
2.run:
3.currentThread:静态方法,获取当前正在执行的线程
4.getId:返回此线程的唯一标识
5.setName(String):设置当前线程的name
6.getName:获取当前线程的name
7.getPriority:获取当前线程的优先级
8.setPriority(int):设置当前线程的优先级
9.getState():获取当前线程的声明周期
10.interrupt():中断线程的执行
11.interrupted():查看当前线程是否中断

 

posted @ 2022-08-03 18:45  房雪莹  阅读(21)  评论(0编辑  收藏  举报