溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Java多線程并發(fā)、并行、線程與進(jìn)程實例分析

發(fā)布時間:2022-06-15 11:52:24 來源:億速云 閱讀:136 作者:iii 欄目:開發(fā)技術(shù)

本篇內(nèi)容介紹了“Java多線程并發(fā)、并行、線程與進(jìn)程實例分析”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

一、并發(fā)與并行

  • 并發(fā):指兩個或多個事件在同一個時間段內(nèi)發(fā)生。

  • 并行:指兩個或多個事件在同一時刻發(fā)生(同時發(fā)生)。

Java多線程并發(fā)、并行、線程與進(jìn)程實例分析

在操作系統(tǒng)中,安裝了多個程序,并發(fā)指的是在一段時間內(nèi)宏觀上有多個程序同時運(yùn)行,這在單 CPU 系統(tǒng)中,每一時刻只能有一道程序執(zhí)行,即微觀上這些程序是分時的交替運(yùn)行,只不過是給人的感覺是同時運(yùn)行,那是因為分時交替運(yùn)行的時間是非常短的。 而在多個 CPU 系統(tǒng)中,則這些可以并發(fā)執(zhí)行的程序便可以分配到多個處理器上(CPU),實現(xiàn)多任務(wù)并行執(zhí)行,即利用每個處理器來處理一個可以并發(fā)執(zhí)行的程序,這樣多個程序便可以同時執(zhí)行。目前電腦市場上說的多核 CPU,便是多核處理器,核 越多,并行處理的程序越多,能大大的提高電腦運(yùn)行的效率。

注意:單核處理器的計算機(jī)肯定是不能并行的處理多個任務(wù)的,只能是多個任務(wù)在單個CPU上并發(fā)運(yùn)行。同理,線程也是一樣的,從宏觀角度上理解線程是并行運(yùn)行的,但是從微觀角度上分析卻是串行運(yùn)行的,即一個線程一個線程的去運(yùn)行,當(dāng)系統(tǒng)只有一個CPU時,線程會以某種順序執(zhí)行多個線程,我們把這種情況稱之為線程調(diào)度。

二、線程與進(jìn)程

  • 進(jìn)程:是指一個內(nèi)存中運(yùn)行的應(yīng)用程序,每個進(jìn)程都有一個獨(dú)立的內(nèi)存空間,一個應(yīng)用程序可以同時運(yùn)行多個進(jìn)程;進(jìn)程也是程序的一次執(zhí)行過程,是系統(tǒng)運(yùn)行程序的基本單位;系統(tǒng)運(yùn)行一個程序即是一個進(jìn)程從創(chuàng)建、運(yùn)行到消亡的過程。

  • 線程:線程是進(jìn)程中的一個執(zhí)行單元,負(fù)責(zé)當(dāng)前進(jìn)程中程序的執(zhí)行,一個進(jìn)程中至少有一個線程。一個進(jìn)程中是可以有多個線程的,這個應(yīng)用程序也可以稱之為多線程程序。

簡而言之:一個程序運(yùn)行后至少有一個進(jìn)程,一個進(jìn)程中可以包含多個線程

我們可以再電腦底部任務(wù)欄,右鍵----->打開任務(wù)管理器,可以查看當(dāng)前任務(wù)的進(jìn)程: 進(jìn)程 

Java多線程并發(fā)、并行、線程與進(jìn)程實例分析

 線程 

 線程調(diào)度:

  • 分時調(diào)度:所有線程輪流使用 CPU 的使用權(quán),平均分配每個線程占用 CPU 的時間。

  • 搶占式調(diào)度:優(yōu)先讓優(yōu)先級高的線程使用 CPU,如果線程的優(yōu)先級相同,那么會隨機(jī)選擇一個(線程隨機(jī)性),Java使用的為搶占式調(diào)度。

  • 設(shè)置線程的優(yōu)先級

Java多線程并發(fā)、并行、線程與進(jìn)程實例分析

搶占式調(diào)度詳解:

大部分操作系統(tǒng)都支持多進(jìn)程并發(fā)運(yùn)行,現(xiàn)在的操作系統(tǒng)幾乎都支持同時運(yùn)行多個程序。比如:現(xiàn)在我們上課一邊使用編輯器,一邊使用錄屏軟件,同時還開著畫圖板,dos窗口等軟件。此時,這些程序是在同時運(yùn)行,”感覺這些軟件好像在同一時刻運(yùn)行著“。 實際上,CPU(中央處理器)使用搶占式調(diào)度模式在多個線程間進(jìn)行著高速的切換。對于CPU的一個核而言,某個時刻,只能執(zhí)行一個線程,而 CPU的在多個線程間切換速度相對我們的感覺要快,看上去就是在同一時刻運(yùn)行。 其實,多線程程序并不能提高程序的運(yùn)行速度,但能夠提高程序運(yùn)行效率,讓CPU的使用率更高。 

Java多線程并發(fā)、并行、線程與進(jìn)程實例分析

三、創(chuàng)建線程類

Java使用java.lang.Thread類代表線程,所有的線程對象都必須是Thread類或其子類的實例。每個線程的作用是完成一定的任務(wù),實際上就是執(zhí)行一段程序流即一段順序執(zhí)行的代碼。Java使用線程執(zhí)行體來代表這段程序流。Java中通過繼承Thread類來創(chuàng)建啟動多線程的步驟如下:

  • 定義Thread類的子類,并重寫該類的run()方法,該run()方法的方法體就代表了線程需要完成的任務(wù),因此把run()方法稱為線程執(zhí)行體。

  • 創(chuàng)建Thread子類的實例,即創(chuàng)建了線程對象

  • 調(diào)用線程對象的start()方法來啟動該線程

代碼如下: 測試類:

public class Demo01 {
	public static void main(String[] args) {
		//創(chuàng)建自定義線程對象
		MyThread mt = new MyThread("新的線程!");
		//開啟新線程
		mt.start();
		//在主方法中執(zhí)行for循環(huán)
		for (int i = 0; i < 10; i++) {
			System.out.println("main線程!"+i);
		}
	}
}

自定義線程類:

public class MyThread extends Thread {
	//定義指定線程名稱的構(gòu)造方法
	public MyThread(String name) {
		//調(diào)用父類的String參數(shù)的構(gòu)造方法,指定線程的名稱
		super(name);
	}
	/**
	 * 重寫run方法,完成該線程執(zhí)行的邏輯
	 */
	@Override
	public void run() {
		for (int i = 0; i < 10; i++) {
			System.out.println(getName()+":正在執(zhí)行!"+i);
		}
	}
}

“Java多線程并發(fā)、并行、線程與進(jìn)程實例分析”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI