停止线程
◆不推荐使用JDK提供的stop()、destroy()方法。[已废弃]
◆推荐线程自己停止下来
◆建议使用一个标志位进行终止变量
当flag=false,则终止线程运行。
线程休眠.
◆sleep (时间)指定当前线程阻塞的毫秒数;(1000)为1s
◆sleep存在异常InterruptedException;
◆sleep时间达到后线程进入就绪状态;
◆sleep可以模拟网络延时,倒计时等。可将问题放大
每一个对象都有一个锁,sleep不会释放锁;
线程礼让
礼让线程,让当前正在执行的线程暂停,但不阻塞
◆将线程从运行状态转为就绪状态
◆让cpu重新调度,礼让不一定成功!看CPU心情
Thread.yield();//礼让
Join
◆Join合并线程,待此线程执行完成后,再执行其他线程,其他线程阻塞
◆可以理解成插队
一开始两线程同时执行 当主线程执行到i=200时 thread开始插队 知道执行完才执行main主线程
public static void main(String[] args) throws InterruptedException {
TestJoin testjoin = new TestJoin();
Thread thread = new Thread(testjoin);
thread.start();
for(int i = 0;i<1000;i++) {
if(i == 200) {
thread.join();//插队
}
System.out.println("主线程" + i);
}
}
@Override
public void run() {
for(int i = 0;i<800;i++) {
System.out.println("vip" + i);
}
}
观测
Thread.State state = thread.getState(); 获得线程状态
public static void main(String[] args) throws InterruptedException {
Thread thread = new Thread(()-> {
for(int i = 0;i<5;i++) {
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println("vip" + i);
}
System.out.println("vip" );
});
Thread.State state = thread.getState();
System.out.println(state);//未启动前是 NEW
thread.start();
state = thread.getState();
System.out.println(state);//启动后是Run
while(state != Thread.State.TERMINATED) {
Thread.sleep(100);
state = thread.getState();//每次都需要更新 才会变
System.out.println(state);
}
}
优先级
thread2.setPriority(1);
thread2.start();
thread3.setPriority(4);
thread3.start();
thread4.setPriority(Thread.MAX_PRIORITY);//MAX_PRIORITY = 10
thread4.start();
守护(daemon)线程
线程分为用户线程和守护线程
虚拟机必须确保用户线程执行完毕
虚拟机不用等待守护线程执行完毕
功能如,后台记录操作日志,监控内存,垃圾回收等待
设置成守护线程
thread.setDaemon(true);//默认是false是用户线程 正常的线程都是用户线程