参考文献:《Java疯狂讲义》(第三版)
run()方法:方法体即线程执行体
线程Target
执行体:run或call方法
call()方法:可以用get()来获取返回值
线程生命周期:
1、new;新建
2、runnable;就绪
3、running;运行
4、blocked;阻塞
可以用sleep方法或者suspend方法进入阻塞状态
5、dead;死亡
新建——>就绪——>运行——>死亡
新建通过start方法进入就绪状态;
运行通过阻塞回到就绪状态;
通过以下情形进入阻塞:
1、sleep或suspend
2、IO阻塞
3、等到同步锁、等待通知
运行时通过stop方法或者run方法、call方法执行体完成进入死亡状态
或捕捉到error或异常;
所有现代的桌面和服务器操作系统都采用了抢占式调度策略
join方法(插队):让某线程等待调用join方法的线程
后台线程:为其他线程提供服务
setDaemon(true)成为后台线程
特征:
1、前台线程都死亡,后台线程自动死亡;
例:JVM垃圾回收线程
注意:setDaemon必须放在start方法前调用
线程让步:yield()方法
某线程调用yield 方法后:you优先级比当前线程更高的处于就绪状态的线程,才会获得执行机会
sleep方法与yield方法的区别:
1、sleep暂停后,会给其他线程机会;yield方法只会给优先级相同或更高的线程机会;
2、阻塞状态sleep
就绪状态yield
3、yield无捕捉异常
4、sleep方法具有更高的可移植性
改变线程优先级
默认与创建它的父线程优先级相同
线程同步:
线程安全问题:
逻辑:加锁——>修改——>释放所
synchronized关键字
使用synchronized关键字修饰方法令该方法成为同步方法
或synchronized(obj){...}
线程通信
wait方法等待
notify方法唤醒
notifyAll方法唤醒所有
由同步监视器对象调用
Condition控制线程通信
接口BlockingQueue控制线程通信:两个线程通过交替向BlockingQueue中放入元素、取出元素
即可很好地控制线程的通信
线程组ThreadGroup来表示线程组,它可以对一批线程进行分类管理,Java允许程序直接对线程组进行控制
线程池
1、池的概念
2、线程池可以有效地控制系统中并发线程的数量
相关类
ThreadLocal类,它代表一个线程局部变量,通过把数据放在ThreadLocal中就可以让每个线程创建一个该变量的副本
线程安全集合类
以Concurrent开头的集合类代表了支持并发访问的集合,它们支持多个线程并发写入访问,这些写入访问的操作都是安全的