1. 程式人生 > 實用技巧 >千鋒教育網路安全學習筆記1-IP詳解極簡單的DOS命令

千鋒教育網路安全學習筆記1-IP詳解極簡單的DOS命令

執行緒狀態

學習材料來源於網路
如有侵權,聯絡刪除

系統排程

  1. New∶尚未啟動的執行緒的執行緒狀態。
  2. Runnable:可執行執行緒的執行緒狀態,等待CPU排程。
  3. Blocked:執行緒阻塞等待監視器鎖定的執行緒狀態。處於synchronized同步程式碼塊或方法中被阻塞。
  4. Waiting:等待執行緒的執行緒狀態。下列不帶超時的方式:Object.wait、Thread.join、LockSupport.park
  5. Timed Waiting:具有指定等待時間的等待執行緒的執行緒狀態。下列帶超時的方式:
    Thread.sleep、Object.wait、Thread.join、LockSupport.parkNanos、LockSupport.parkUntil
  6. Terminated:終止執行緒的執行緒狀態。執行緒正常完成執行或者出現異常。

示例1

package com.study.hc.thread.chapter1.thread;

/**
 * 示例2 - 多執行緒執行狀態切換示例 <br/>
 */
public class Demo2 {
	public static Thread thread1;
	public static Demo2 obj;

	public static void main(String[] args) throws Exception {
		// 第一種狀態切換 - 新建 -> 執行 -> 終止
		System.out.println("#######第一種狀態切換  - 新建 -> 執行 -> 終止################################");
		Thread thread1 = new Thread(new Runnable() {
			@Override
			public void run() {
				System.out.println("thread1當前狀態:" + Thread.currentThread().getState().toString());
				System.out.println("thread1 執行了");
			}
		});
		System.out.println("沒呼叫start方法,thread1當前狀態:" + thread1.getState().toString());
		thread1.start();
		Thread.sleep(2000L); // 等待thread1執行結束,再看狀態
		System.out.println("等待兩秒,再看thread1當前狀態:" + thread1.getState().toString());
		// thread1.start(); TODO 注意,執行緒終止之後,再進行呼叫,會丟擲IllegalThreadStateException異常

		System.out.println();
		System.out.println("############第二種:新建 -> 執行 -> 等待 -> 執行 -> 終止(sleep方式)###########################");
		Thread thread2 = new Thread(new Runnable() {
			@Override
			public void run() {
				try {// 將執行緒2移動到等待狀態,1500後自動喚醒
					Thread.sleep(1500);
				} catch (InterruptedException e) {
					e.printStackTrace();
				}
				System.out.println("thread2當前狀態:" + Thread.currentThread().getState().toString());
				System.out.println("thread2 執行了");
			}
		});
		System.out.println("沒呼叫start方法,thread2當前狀態:" + thread2.getState().toString());
		thread2.start();
		System.out.println("呼叫start方法,thread2當前狀態:" + thread2.getState().toString());
		Thread.sleep(200L); // 等待200毫秒,再看狀態
		System.out.println("等待200毫秒,再看thread2當前狀態:" + thread2.getState().toString());
		Thread.sleep(3000L); // 再等待3秒,讓thread2執行完畢,再看狀態
		System.out.println("等待3秒,再看thread2當前狀態:" + thread2.getState().toString());

		System.out.println();
		System.out.println("############第三種:新建 -> 執行 -> 阻塞 -> 執行 -> 終止###########################");
		Thread thread3 = new Thread(new Runnable() {
			@Override
			public void run() {
				synchronized (Demo2.class) {
					System.out.println("thread3當前狀態:" + Thread.currentThread().getState().toString());
					System.out.println("thread3 執行了");
				}
			}
		});
		synchronized (Demo2.class) {
			System.out.println("沒呼叫start方法,thread3當前狀態:" + thread3.getState().toString());
			thread3.start();
			System.out.println("呼叫start方法,thread3當前狀態:" + thread3.getState().toString());
			Thread.sleep(200L); // 等待200毫秒,再看狀態
			System.out.println("等待200毫秒,再看thread3當前狀態:" + thread3.getState().toString());
		}
		Thread.sleep(3000L); // 再等待3秒,讓thread3執行完畢,再看狀態
		System.out.println("等待3秒,讓thread3搶到鎖,再看thread3當前狀態:" + thread3.getState().toString());

	}
}

執行結果