线程属于某个进程,通过一个进程中的线程共享所属进程的资源;
- Java中线程:
a.java.lang.Thread类的一个实例;
b.线程的执行;
继承java.lang.Thread类:
实现java.lang.Runnable接口: - 主线程:main方法;
- 一个线程有一个调用栈,没创建一个新线程就会产生一个新的调用栈;
- 线程总体分类:
用户线程:用户线程执行完毕,JVM自动关闭;
守护线程:独立于JVM,一般由操作系统或用户创建; - Thread对象调用start()方法才会启动线程,而不是通过run()或者其他的方法;
start()方法调用前线程属于new的状态只有一个Thread对象,并没有真正的线程;
start()调用后:启动新的执行线程伴随着新的调用栈,该线程从new的状态转到
runnable状态,当线程获得机会执行时,便进入run()方法中运行;
run()方法类似于main方法只是一个入口,线程有机会执行时会去调用run方法执行,因此在runnable或thread上调用run是合法的,但并没什么卵用,也不会启动新的线程,所以run只是一个签名,告诉线程从这里进入执行;线程一旦启动就永远不能重新启动,一旦启动就进入就绪的状态,即可运行的状态; - 线程的调度不可控,但可以通过特定的操作影响其调度方式;
线程生命周期
- 线程通过new()方法创建(有两种方式),调用start()方法,进入就绪状态(runnable状态),等待系统的调度(时间片轮转调度),当系统调度,线程获取cpu时间片进入运行状态(running)。线程执行完毕,进入死亡状态。
- 处于运行状态的线程若遇到**sleep()**方法(Thread的静态方法),则线程进入睡眠状态(blocked),不会释放锁,sleep()方法结束,线程转为就绪状态,等待系统重新调度(所以sleep()结束不一定会立即执行)。
- 处于运行状态的线程有io操作或者有其他线程的join()方法,也会进入阻塞状态(blocked)【关于join方法,join方法用得不多,当A线程执行到了B线程的join()方法时,A就会等待,等B线程都运行完,A线程才会执行。使用join()方法时,会产生异常】。
- 处于运行状态的线程yield()方法,线程转为就绪状态。(yield只让给优先级比自己高的线程)
- 处于运行状态的线程遇到wait() 方法(object的方法),线程处于等待状态,需要notify()/notifyALL()来唤醒线程,唤醒后的线程处于锁定状态,获取了“同步锁”,之后,线程才转为就绪状态。
- 处于运行的线程synchronized,加上后 变成同步操作。处于锁定状态,获取了“同步锁”,之后,线程才转为就绪状态。