线程是一个子任务,CPU以不确定的方式,或者说是以随机的时间来调用线程中的run方法。
执行start()方法的顺序并不代表线程启动的顺序
start()方法通知 线程规划器 此线程已经准备就绪,等待调用线程对象的run()方法,具有异步执行的效果
继承Thread类和实现Runnable接口的方式并没有不同,但是实现接口能解决Java只有单继承的问题
synchrinized加锁,互斥区,临界区
i–与System.out.println()的异常
isAlive()判断当前线程是否处于活动状态
停止线程
1.run方法执行完成,正常退出 2.stop强行终止(不推荐) 3.interrupt中断线程thread.interrupt:不会真正终止一个正在运行的进程,相当于外界给某个线程发出停止的信号,线程中对这个信号进行判断,最后结束
判断线程是否是停止状态
-
this.interrupted():
测试当前线程是否已经中断,并且清除线程的中断状态,static- 当前线程是指运行this.interrupted()方法的线程
- 连续两次调用该方法,第一次如果为true,那么第二次会是false
-
this.isInterrupted():
测试线程是否已经中断,不清除中断状态,非static扫描二维码关注公众号,回复: 6002849 查看本文章
能停止的线程——异常法
this.interrupted()
为true时,抛出InterruptedException
,然后捕获这个异常,并放弃执行try中后续语句,执行完catch
语句中的内容后,就能直接结束线程了
沉睡停止法
在线程中调用sleep
方法会抛出InterruptedException
异常,捕获这个异常
return停止法
和异常法差不多,只是不抛出异常,而是使用return
结束线程
建议使用抛出异常的方法来实现线程的停止,会因为在catch块中可以对异常的信息进行相关的处理,
而且使用异常流能更好、更方便的控制程序运行流程,不至于代码中出现很多个reutrn,造成污染。
暂停线程
suspend暂停线程,resume恢复线程缺点:
- 如果使用不当,极容易造成公共的同步对象的独占,使得其他线程无法访问公共同步对象。
- 出现因为线程的暂停而导致数据不同步的情况。
yield方法:
放弃当前的CPU资源,将它让给其他的任务去占用CPU执行时间;放弃的时间不确定,有可能刚刚放弃,马上又获得CPU时间片。
线程的优先级
- 优先级较高的线程得到的CPU资源较多,也就是会先执行;
- Java中优先级分为1~10这10个等级,如果在这个范围之外,会抛出IllegalArgumentException
- 线程优先级具有继承性
- 线程优先级具有规则性,高优先级的线程总是的大部分先执行完,当优先级差距很大时,谁先执行完和调用顺序无关
- 线程优先级具有随机性,优先级高的不一定每次都先执行完
Java中的两种线程
用户线程:
守护线程:
守护线程是一种特殊的线程,它的特性有陪伴的含义,当进程中不存在非守护线程了,则守护线程自动销毁(垃圾回收线程)。