成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

.NET上執行多線程應該注意的兩點

開發 后端
在初嘗多線程操作的甜頭后,總會想學習更多復雜的項目以便可以真正探索這個問題,并能充分利用其功能。通常,你所面臨的挑戰有兩個:線程管理和數據完整性。

線程管理

線程管理現在變得越來越容易了。在.NET架構中,你可以從線程池中獲取線程。線程池是一個生成線程的工廠,如果它已經生成了一定數量的線程且還沒有被破壞的話,對它的調用會被阻止。但是,如何確保不會有太多的線程在規定時間內運行?畢竟,如果每個線程能夠占用一個CPU核的100%,那么有超過CPU核數量的線程運行,只會導致操作系統啟動線程時間分配,這將導致上下文切換和低效率運行。換句話說,同一核上的兩個線程不會以兩倍的時長完成,可能需要用兩倍再加10%左右的時間來完成。與一個線程相比較的話,三個線程在同一核上想占用100%的CPU使用率可能會需要3.25—3.5倍的時長來完成。我的經驗是,每個核都有多個線程試圖占用100%的CPU,但它們都不能達到目標。

所以,要怎樣分配正在運行的線程數量呢?

有一個辦法是在線程之間建立一個共享的旗語對象。在線程開始運行前,它會嘗試調用旗語的WaitOne模式,并在完成后釋放旗語。對CPU的核數量設置旗語限制,(使用EnvironmentProcessorCount功能限定);這將防止您的系統在同一時間運行的線程數多于核數量。與此同時,從線程池中拉出線程將確保您不會在同一時間創建過多線程。如果一次創建線程過多,即使他們并沒運行,那也是浪費系統資源。因為每個線程都要消耗資源。使用旗語的一般模式如下所示:

static Semaphore threadBlocker; 
static void Execute(object state)
{threadBlocker.WaitOne(); //Do work threadBlocker.Release(); }
static void RunThreads()
{threadBlocker = new Semaphore(0, Environment.ProcessorCount); 
for(int x = 0; x <= 2000; x++)
{ThreadPool.QueueUserWorkItem(new WaitCallback (Execute)); } 
}

當然還有其他一些辦法可以解決這一問題。前一段時間我想要保持對象的一份清單。每個對象代表每個工人部件的完整狀態。執行和完成時,工人部件都會被填入數據。并且他會設置某個功能以指示任務完成。主線程將掃描對象清單,如果運行的線程數量足夠少,就開始運行另一個。說實話,雖然這個方法可行,但對于代碼和調試來說這絕對是個噩夢,所以我一點也不推薦。

數據完整性

總體而言,在數據完整性方面,你要擔心的問題是競爭條件和死鎖。多個線程試圖在同一時間更新相同的對象就會造成競爭條件,這將招致麻煩。想象一下如果使用下面這段代碼:

int x=5;

x=x+10;

現在,如果線程A和線程B在同一時間運行此代碼,將會發生什么情況?它可以運行得很好?還是會出現什么問題?如果出現問題,又是些怎樣的問題呢?每個線程都不會一次執行全部語句。因此,我們可以按照以下順序操作:

1. Thread A retrieves the value of x (5).
2. Thread B retrieves the value of x (5).
3. Thread A assigns x + 10 (15) to x.
4. Thread B assigns x + 10 (15) to x.
5. x is now equal to 15.

或者,相同的代碼可以按照不同的順序:

1. Thread A retrieves the value of x (5).
2. Thread A assigned x = 10 (15) to x.
3. Thread B retrieves the value of x (15).
4. Thread B assigns x + 10 (25) to x.
5. x is now equal to 25.

在.NET架構中,最簡單也最常見的解決競爭條件的方法是使用“臨界區”。而在VB.NET中,該語句是“加鎖”,并在C#中是“鎖定”,這兩種語句都是把對象作為參數。其他嘗試鎖定相同對象實例使用的臨界區(包括上文所指的)會阻止運行直到鎖定解除,這樣每次就只有一個臨界區運行。我們先前舉例的一段代碼現在看起來是這樣的:

int x=5; 
object lockObject=new object();
Monitor.Enter(lockObject);
x=x+10;
Monitor.Exit(lockObject);

什么是監控器可以提供而臨界區做不到的呢?答案是沒有。除非你在解鎖后需要更細粒度的控制權。有些復雜的代碼可能需要鎖定或長或短的一段時間,這都取決于運行的情況,比方一個變量的值。在這種情況下,選擇監控器要比需選擇臨界區更合適。

另一個值得關注的有關數據完整性的問題是死鎖。當多個線程鎖定資源導致它們都不能夠繼續運行時,就會出現死鎖。例如:

Thread A: 
Monitor.Enter(object1);
Monitor.Enter(object2);
//Do work
Monitor.Exit(object1);
Monitor.Exit(object2);
Thread B:
Monitor.Enter(object2);
Monitor.Enter(object1);
//Do work
Monitor.Exit(object1);
Monitor.Exit(object2);

如果線程A和線程B都調用它們的第一段語句并且同時完成運行,那它們都無法調用它們的第二段語句——這就是一個死鎖。所以編寫代碼的時候細心,要仔細想清楚怎樣編寫代碼才更有利。死鎖的發生常見于新手,因為他們過分設置鎖定把它變得太詳細了。如果代碼被嵌套鎖定通常表明需要對編寫的代碼加以認真檢查。

【編輯推薦】

  1. .NET中異常處理的幾個誤區
  2. 使用Ja.Net實現Java和.NET的完美互用
  3. 基于.NET平臺的分層架構實戰
責任編輯:田超 來源: IT專家網論壇
相關推薦

2009-07-16 09:25:27

Java常量定義

2018-08-28 06:21:19

網線布線線纜

2021-08-26 14:55:55

開發React代碼

2012-11-12 09:26:06

.NET多線程

2013-01-05 14:25:27

大數據

2011-04-29 08:46:58

C#代碼規范

2010-03-18 16:02:09

python 多線程

2021-05-28 17:33:33

5G5G網絡工業互聯網

2015-08-03 10:25:58

C語言特性不為人知

2010-04-14 09:20:26

.NET多線程

2024-04-30 12:56:00

多線程.NET

2009-07-28 15:30:34

ASP.NET多線程

2009-12-30 14:14:39

PPPoA體系

2022-04-10 23:07:21

瀏覽器FirefoxLinux

2010-02-02 09:54:05

軟交換技術

2010-05-13 11:12:59

統一通信平臺

2010-03-17 15:45:13

無線設備兼容性

2012-08-23 11:18:15

2009-07-01 14:49:52

JSP空間租用

2009-07-21 17:09:47

ASP.NET多線程
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 日韩字幕一区 | 激情五月激情综合网 | 婷婷五月色综合香五月 | 国产高清精品网站 | 在线观看中文字幕dvd播放 | 一区二区三区av | 国产精品久久久久免费 | 亚洲福利 | 日韩精品一区二区三区中文在线 | 亚洲成人精品国产 | 亚洲视频免费观看 | 中文字幕免费视频 | 国产精品一码二码三码在线 | 久久爱综合 | 日本三级电影在线看 | 欧美一级欧美三级在线观看 | 三级成人在线 | 开操网 | 欧美 日韩 国产 一区 | 精品国产黄a∨片高清在线 成人区精品一区二区婷婷 日本一区二区视频 | 在线播放一区二区三区 | 亚洲免费三区 | 精品福利在线视频 | 伊人色综合久久天天五月婷 | 亚洲高清在线观看 | 日本不卡一二三 | 成人免费观看视频 | 久久久久久久久久久爱 | 午夜免费电影院 | 色伊人网 | 中文字幕av在线 | 中文字幕日韩欧美一区二区三区 | 亚洲精品视频在线看 | 欧美激情在线精品一区二区三区 | 国产目拍亚洲精品99久久精品 | 精品一区二区三区四区 | 日本电影免费完整观看 | 久久综合久久久 | 亚洲欧美在线视频 | 日韩av手机在线观看 | 男女污污动态图 |