1. 程式人生 > >多線程快速入門

多線程快速入門

bubuko als 守護線程 進入 占用 是否存活 target true schedule

應用程序:就是可以執行的軟件,如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 核數

技術分享圖片

技術分享圖片

技術分享圖片

技術分享圖片

技術分享圖片

多線程快速入門