多線程快速入門
應用程序:就是可以執行的軟件,如QQ、YY語言。
什麽進程:就是正在運行的程序,是所有線程的集合。
什麽線程:每一個線程是進程中的一條執行路徑,一個獨立執行的單元。(是獨立運行的一個執行路徑或者執行順序)。 每個線程互補影響,因為自己都是獨立運行的。
創建線程有方式:
繼承Thread類,2、實現Runnanle接口、3、使用匿名內部類、4、實現Callable接口 ,5、線程池創建
多線程第一種實現方式: 繼承Thread類,覆蓋run()方法。
Thread源碼解析: public class Thread implements Runnable {} 啟動線程用start()方法;
為什麽要調用start()方法啟動線程 1、start();//啟動線程,使虛擬機調用該線程的 run 方法。
private native void start0();
為什麽要覆蓋run方法;將自定義的代碼存儲在run方法中,讓線程運行。 Thread類用於描述線程:因為該類定義了一個功能,存儲線程要運行的代碼,該存儲代碼就是run方法;
Java中有兩種線程,一種是用戶線程,另一種是守護線程。
用戶線程是指用戶自定義創建的線程,主線程停止,用戶線程不會停止。 守護線程當進程不存在或主線程停止,守護線程也會被停止。(GC線程) 守護線程和主線程一起銷毀
多線程運行狀態
線程從創建、運行到結束總是處於下面五個狀態之一:新建狀態、就緒狀態、運行狀態、阻塞狀態及死亡狀態。
新建狀態
當用new操作符創建一個線程時, 例如new Thread(r),線程還沒有開始運行,此時線程處在新建狀態。 當一個線程處於新生狀態時,程序還沒有開始運行線程中的代碼
就緒狀態
一個新創建的線程並不自動開始運行,要執行線程,必須調用線程的start()方法。當線程對象調用start()方法即啟動了線程,start()方法創建線程運行的系統資源,並調度線程運行run()方法。當start()方法返回後,線程就處於就緒狀態。
處於就緒狀態的線程並不一定立即運行run()方法,線程還必須同其他線程競爭CPU時間,只有獲得CPU時間才可以運行線程。因為在單CPU的計算機系統中,不可能同時運行多個線程,一個時刻僅有一個線程處於運行狀態。因此此時可能有多個線程處於就緒狀態。對多個處於就緒狀態的線程是由Java運行時系統的線程調度程序(thread scheduler
運行狀態
當線程獲得CPU時間後,它才進入運行狀態,真正開始執行run()方法.
阻塞狀態
線程運行過程中,可能由於各種原因進入阻塞狀態:
1>線程通過調用sleep方法進入睡眠狀態;
2>線程調用一個在I/O上被阻塞的操作,即該操作在輸入輸出操作完成之前不會返回到它的調用者;
3>線程試圖得到一個鎖,而該鎖正被其他線程持有;
4>線程在等待某個觸發條件;
死亡狀態
有兩個原因會導致線程死亡:
1) run方法正常退出而自然死亡,
2) 一個未捕獲的異常終止了run方法而使線程猝死。
為了確定線程在當前是否存活著(就是要麽是可運行的,要麽是被阻塞了),需要使用isAlive方法。如果是可運行或被阻塞,這個方法返回true; 如果線程仍舊是new狀態且不是可運行的, 或者線程死亡了,則返回false.
join()方法作用
join作用是讓其他線程變為等待, t1.join();// 讓其他線程變為等待,直到當前t1線程執行完畢,才釋放。
thread.Join把指定的線程加入到當前線程,可以將兩個交替執行的線程合並為順序執行的線程。比如在線程B中調用了線程A的Join()方法,直到線程A執行完畢後,才會繼續執行線程B。
Yield方法
Thread.yield()方法的作用:暫停當前正在執行的線程,並執行其他線程。(可能沒有效果)
yield()讓當前正在運行的線程回到可運行狀態,以允許具有相同優先級的其他線程獲得運行的機會。因此,使用yield()的目的是讓具有相同優先級的線程之間能夠適當的輪換執行。但是,實際中無法保證yield()達到讓步的目的,因為,讓步的線程可能被線程調度程序再次選中。
多線程分批處理數據
需求:目前XX網站20萬個用戶,現在需要做活動,給每一個用戶發送一條祝福短信。
為了提高數程序的效率,請使用多線程技術分批發送據。
每開一個線程,都會占用CPU資源
服務器(電腦)配置 CPU 核數
多線程快速入門