溫馨提示×

溫馨提示×

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

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

細說多線程(一)—— 線程的定義

發(fā)布時間:2020-06-15 18:35:59 來源:網(wǎng)絡(luò) 閱讀:2495 作者:leslies2 欄目:編程語言

引言

本文主要從線程的基礎(chǔ)用法,CLR線程池當(dāng)中工作者線程與I/O線程的開發(fā),并行操作PLINQ等多個方面介紹多線程的開發(fā)。
其中委托的BeginInvoke方法以及回調(diào)函數(shù)最為常用。
而 I/O線程可能容易遭到大家的忽略,其實在開發(fā)多線程系統(tǒng),更應(yīng)該多留意I/O線程的操作。特別是在ASP.NET開發(fā)當(dāng)中,可能更多人只會留意在客戶端 使用Ajax或者在服務(wù)器端使用UpdatePanel。其實合理使用I/O線程在通訊項目或文件下載時,能盡可能地減少IIS的壓力。
并行編程是Framework4.0中極力推廣的異步操作方式,更值得更深入地學(xué)習(xí)。
希望本篇文章能對各位的學(xué)習(xí)研究有所幫助,當(dāng)中有所錯漏的地方敬請點評。

目錄

一、線程的定義

二、線程的基礎(chǔ)知識

三、以ThreadStart方式實現(xiàn)多線程

四、CLR線程池的工作者線程

五、CLR線程池的I/O線程

六、異步 SqlCommand

七、并行編程與PLINQ

八、計時器與鎖

 

一、線程的定義

 1. 1 進程、應(yīng)用程序域與線程的關(guān)系

進程(Process)是Windows系統(tǒng)中的一個基本概念,它包含著一個運行程序所需要的資源。進程之間是相對獨立的,一個進程無法訪問另一個 進程的數(shù)據(jù)(除非利用分布式計算方式),一個進程運行的失敗也不會影響其他進程的運行,Windows系統(tǒng)就是利用進程把工作劃分為多個獨立的區(qū)域的。進 程可以理解為一個程序的基本邊界。

應(yīng)用程序域(AppDomain)是一個程序運行的邏輯區(qū)域,它可以視為一個輕量級的進程,.NET的程序集正是在應(yīng)用程序域中運行的,一個進程可 以包含有多個應(yīng)用程序域,一個應(yīng)用程序域也可以包含多個程序集。在一個應(yīng)用程序域中包含了一個或多個上下文context,使用上下文CLR就能夠把某些 特殊對象的狀態(tài)放置在不同容器當(dāng)中。

線程(Thread)是進程中的基本執(zhí)行單元,在進程入口執(zhí)行的第一個線程被視為這個進程的主線程。在.NET應(yīng)用程序中,都是以Main()方法 作為入口的,當(dāng)調(diào)用此方法時系統(tǒng)就會自動創(chuàng)建一個主線程。線程主要是由CPU寄存器、調(diào)用棧和線程本地存儲器(Thread Local Storage,TLS)組成的。CPU寄存器主要記錄當(dāng)前所執(zhí)行線程的狀態(tài),調(diào)用棧主要用于維護線程所調(diào)用到的內(nèi)存與數(shù)據(jù),TLS主要用于存放線程的狀 態(tài)信息。

進程、應(yīng)用程序域、線程的關(guān)系如下圖,一個進程內(nèi)可以包括多個應(yīng)用程序域,也有包括多個線程,線程也可以穿梭于多個應(yīng)用程序域當(dāng)中。但在同一個時刻,線程只會處于一個應(yīng)用程序域內(nèi)。

細說多線程(一)—— 線程的定義

 
由于本文是以介紹多線程技術(shù)為主題,對進程、應(yīng)用程序域的介紹就到此為止。關(guān)于進程、線程、應(yīng)用程序域的技術(shù),在“C#綜合揭秘——細說進程、應(yīng)用程序域與上下文”會有詳細介紹。

 

1.2 多線程

在單CPU系統(tǒng)的一個單位時間(time slice)內(nèi),CPU只能運行單個線程,運行順序取決于線程的優(yōu)先級別。如果在單位時間內(nèi)線程未能完成執(zhí)行,系統(tǒng)就會把線程的狀態(tài)信息保存到線程的本地 存儲器(TLS) 中,以便下次執(zhí)行時恢復(fù)執(zhí)行。而多線程只是系統(tǒng)帶來的一個假像,它在多個單位時間內(nèi)進行多個線程的切換。因為切換頻密而且單位時間非常短暫,所以多線程可 被視作同時運行。

適當(dāng)使用多線程能提高系統(tǒng)的性能,比如:在系統(tǒng)請求大容量的數(shù)據(jù)時使用多線程,把數(shù)據(jù)輸出工作交給異步線程,使主線程保持其穩(wěn)定性去處理其他問題。但需要注意一點,因為CPU需要花費不少的時間在線程的切換上,所以過多地使用多線程反而會導(dǎo)致性能的下降。

對JAVA與.NET開發(fā)有興趣的朋友歡迎加入QQ群:162338858 細說多線程(一)—— 線程的定義

 

向AI問一下細節(jié)

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

AI