Spark-Java Day 19多线程与泛型

1 多线程
1.1 线程间通信
(1) 创建线程是由于操作系统决定,因此顺序不确定,在程序中通过条件控制,让线程执行有顺序的,这个机制------>等待唤醒机制。
(2)等待唤醒机制调用方法
第一个 wait()方法 线程不再活动,不再参与调度(释放锁,需要被唤醒)
第二个notify()/notifyAll()选取通知的wait()线程释放
均为Object类的方法
(3)编写线程间通信例子
1.2 线程其他概念
a 线程生命周期
线程生命周期五种状态:新建(New), 就绪(Runnable), 运行(Running), 阻塞(Blocked),
死亡(Dead).
b 线程阻塞
- 线程调用了sleep()方法,主动放弃所占用的CPU资源;
- 线程试图获取一个同步监视器,但该同步监视器正被其他线程持有;
- 线程执行过程中,同步监视器调用了wait(),让它等待某个通知(notify);
- 线程执行过程中,同步监视器调用了wait(time)
- 线程执行过程中,遇到了其他线程对象的加塞(join);
c

public enum State {
   
	        	NEW,   新建
		        RUNNABLE,  准备就绪
		        BLOCKED,   阻塞
		        WAITING,   不见不散
		        TIMED_WAITING, 过时不候
		        TERMINATED;    终结
	   		 }

1.3 Thread和Runnable区别
1. 适合多个相同的程序代码的线程去共享同一个资源。
2. 可以避免java中的单继承的局限性。
3. 增加程序的健壮性,实现解耦操作,代码可以被多个线程共享,代码和线程独立。
4. 线程池只能放入实现Runable或Callable类线程,不能直接放入继承Thread的类。

1.4 释放锁操作
* 当前线程的同步方法、同步代码块执行结束。
* 当前线程在同步代码块、同步方法中遇到break、return终止了该代码块、该方法的继续执行。
* 当前线程在同步代码块、同步方法中出现了未处理的Error或Exception,导致当前线程异常结束。
* 当前线程在同步代码块、同步方法中执行了锁对象的wait()方法,当前线程被挂起,并释放锁。

1.5 死锁
不同的线程分别锁住对方需要的同步监视器对象不释放,都在等待对方先放弃时就形成了线程的死锁。
一旦出现死锁,整个程序既不会发生异常,也不会给出任何提示,只是所有线程处于阻塞状态,无法继续。

1.6 sleep()和wait()方法的区别
- sleep()不释放锁,wait()释放锁
- sleep()自动在指定时间唤醒,wait()可以指定时间也可以使用notify或notifyAll唤醒
- sleep()在Thread类中声明的静态方法,wait方法在Object类中声明

2 泛型
2.1
(1) jdk1.5之后开始出现的新特性。
(2) 使用泛型可以限定集合或者数组放什么类型数据
2.2 泛型解决问题
<自定义类型>:使用大写字母代表自定义类型
<>可以写在类部分或者方法部分
例子:

class Fan<T>{
   
			    private T a;
			    private T b;

			    public Fan(T a, T b) {
   
			        int c = (Integer)a;
			        int d = (Integer)b;
			}
Fan<Integer> objectFan = new Fan<Integer>(1,5);
Fan<Double> object = new Fan<Double>(1.0,5.5
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值