商务网站开发工具,租用云服务器一年大概的费用,学网站建设要学什么,网站备案了以后1 概念介绍#x1f4cc; 五大状态#xff1a;new#xff1a;Thread t new Thread(); 线程对象一旦被创建就进入到了新生状态#xff1b;就绪状态#xff1a;当调用start()方法#xff0c;线程立即进入就绪状态#xff0c;但不意味着立即调度执行#xff1b;运行状态 五大状态newThread t new Thread(); 线程对象一旦被创建就进入到了新生状态就绪状态当调用start()方法线程立即进入就绪状态但不意味着立即调度执行运行状态进入运行状态线程才真正执行线程体的代码块阻塞状态当调用sleepwait或同步锁定时线程进入阻塞状态此时代码不往下执行阻塞事件解除后重新进入就绪状态等待cpu调度执行dead线程中断或结束一旦进入死亡状态就不能再次启动。如下图 主要方法setPriority() 改变线程的优先级让cpu有个参考的执行顺序。// 数字大小范围 1~10new Thread(new A()).setPriority(4)static void sleep()让当前线程睡眠一定时间睡眠会让线程进入阻塞状态时间到达后重新进入就绪状态每个对象都有一把锁sleep不释放锁void join() 插队将某一个线程强行插队其它线程被阻塞需要等待这个线程去完成后才有资格继续工作new Thread(new A()).join()static void yield()礼让。暂停下当前的线程不阻塞让cpu重新执行一个调度工作等于是多线程们重新再出发void interrupt()中止线程现在不考虑用这个方法了更多考虑用标志位的方法去中止线程boolean isAlive()查看线程是否处于活动状态getState()获得某个线程的状态NEW、RUNNABLE、BLOCKED、WAITING、TIMED_WAITING、TERMINATED2 线程方法实践2.1 线程状态通过state方法可以观察线程的状态public class MyThreadState {public static void main(String[] args) throws InterruptedException {//使用lambda表达式Thread thread new Thread(()-{for (int i 0; i 5; i) {try {Thread.sleep(1000);} catch (InterruptedException e) {e.printStackTrace();}}System.out.println(///);});Thread.State state thread.getState();System.out.println(线程创建未启动时状态:state);thread.start();state thread.getState();System.out.println(线程启动后的状态:state);while (state ! Thread.State.TERMINATED){System.out.println(线程运行时状态:state);Thread.sleep(800);state thread.getState();}state thread.getState();System.out.println(线程结束状态state);}
}控制台输出 能够清楚地看到各状态情况该线程每次睡眠1秒钟第四秒时这个空挡还是运行状态。2.2 线程停止 要点建议线程正常停止; - 一般是利用次数不建议死循环建议使用标志位不建议使用 stop 和 destroy 方法已过时public class MyThreadStop implements Runnable{//1.设置一个标志位private boolean flag true;Overridepublic void run() {int j 0;while (flag){System.out.println(Thread.currentThread().getName()j);}}//2.设置一个公开的方法停止线程public void myStop(){this.flag false;}public static void main(String[] args) {MyThreadStop myThreadStop new MyThreadStop();new Thread(myThreadStop,MyThreadStop).start();for (int i 0; i 50; i) {System.out.println(maini);if (i 30){//3.调用自定义的 myStop方法切换标志位让线程停止myThreadStop.myStop();System.out.println(该线程已停止);}}}
}控制台输出 注意MyThreadStop线程是在main线程输出到main30时停止的说明停止成功。至于MyThreadStop能输出到多少得看cpu的执行或分配。2.3 线程插队用到join()方法优先执行--插队public class MyThreaJoin {public static void main(String[] args) {//使用lambda表达式Thread thread new Thread(()-{for (int i 0; i 5; i) {System.out.println(Thread.currentThread().getName()vip线程开始跑i);}});thread.start();for (int i 0; i 10; i) {if (i 3){try {thread.join();} catch (InterruptedException e) {e.printStackTrace();}}System.out.println(Thread.currentThread().getName()i正在跑);}}
}控制台输出 我这台电脑是main线程跑得快可以看到A线程插队到了main3之前这就是join()方法的作用2.3 线程优先级 要点SetPriority (int i )设置线程优先级GetPriority () 获取线程的优先级三个优先级常量 Thread.MIN_PRIORITY 1; thread.MAX_PRIORITY 10; thread.NORM_PRIORITY 5public class MyThreadPriority {public static void main(String[] args) {//主线程默认优先级System.out.println(Thread.currentThread().getName()的优先级Thread.currentThread().getPriority());MyPriority myPriority new MyPriority();Thread t1 new Thread(myPriority);Thread t2 new Thread(myPriority);Thread t3 new Thread(myPriority);Thread t4 new Thread(myPriority);//先设置优先级再启动t1.start();t2.setPriority(1);t2.start();t3.setPriority(Thread.MAX_PRIORITY);t3.start();t4.setPriority(4);t4.start();}
}class MyPriority implements Runnable{Overridepublic void run() {System.out.println(Thread.currentThread().getName()的优先级Thread.currentThread().getPriority());}
}控制台输出 可以看到优先级默认是5同时线程并不是严格按照优先级的顺序启动这是因为优先级高只是提高了cpu调度的概率具体还得看cpu。2.4 守护线程 要点线程分为用户线程和守护线程虚拟机必须确保用户线程执行完虚拟机不必等待守护线程执行完毕如后台记录日志监控内存垃圾回收线程等都是守护线程。public class MyThreadDaemon {public static void main(String[] args) {You you new You();God god new God();Thread youThread new Thread(you);Thread godThread new Thread(god);godThread.setDaemon(true);//默认是false表示是用户现场正常的线程都是用户现场youThread.start();godThread.start();}
}//上帝守护线程
class God implements Runnable{Overridepublic void run() {long l 0;while (true){System.out.println(上帝保佑你l);}}
}//you 用户线程
class You implements Runnable{Overridepublic void run() {for (int i 0; i 100; i) {System.out.println(每天都在健康的活着i);}System.out.println(you goodBye world!);}
}控制台输出 守护线程并没有设置终止但是他会随着其他线程的终止而终止。