国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當(dāng)前位置: 首頁 - 科技 - 知識(shí)百科 - 正文

.net面向?qū)ο笾嗑€程(Multithreading)及 多線程高級(jí)應(yīng)用

來源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 22:38:24
文檔

.net面向?qū)ο笾嗑€程(Multithreading)及 多線程高級(jí)應(yīng)用

.net面向?qū)ο笾嗑€程(Multithreading)及 多線程高級(jí)應(yīng)用:在.net面向?qū)ο蟪绦蛟O(shè)計(jì)階段在線程資源共享中的線程安全和線程沖突的解決方案;多線程同步,使用線程鎖和線程通知實(shí)現(xiàn)線程同步,具體內(nèi)容介紹如下: 1、 ThreadStatic特性 特性:[ThreadStatic] 功能:指定靜態(tài)字段在不同線程中擁有不同的值 在此之前,我們
推薦度:
導(dǎo)讀.net面向?qū)ο笾嗑€程(Multithreading)及 多線程高級(jí)應(yīng)用:在.net面向?qū)ο蟪绦蛟O(shè)計(jì)階段在線程資源共享中的線程安全和線程沖突的解決方案;多線程同步,使用線程鎖和線程通知實(shí)現(xiàn)線程同步,具體內(nèi)容介紹如下: 1、 ThreadStatic特性 特性:[ThreadStatic] 功能:指定靜態(tài)字段在不同線程中擁有不同的值 在此之前,我們

在.net面向?qū)ο蟪绦蛟O(shè)計(jì)階段在線程資源共享中的線程安全和線程沖突的解決方案;多線程同步,使用線程鎖和線程通知實(shí)現(xiàn)線程同步,具體內(nèi)容介紹如下:

1、 ThreadStatic特性

特性:[ThreadStatic]

功能:指定靜態(tài)字段在不同線程中擁有不同的值

在此之前,我們先看一個(gè)多線程的示例:

我們定義一個(gè)靜態(tài)字段:

 static int num = 0;
 然后創(chuàng)建兩個(gè)線程進(jìn)行分別累加:

new Thread(() =>
{
 for (int i = 0; i < 1000000; i++)
 ++num;
 Console.WriteLine("來自{0}:{1}", Thread.CurrentThread.Name, num);
})
{ Name = "線程一" }.Start(); 

new Thread(() =>
{
 for (int i = 0; i < 2000000; i++)
 ++num;
 Console.WriteLine("來自{0}:{1}", Thread.CurrentThread.Name, num);
})
{ Name = "線程二" }.Start();

運(yùn)行多次結(jié)果如下:

    

可以看到,三次的運(yùn)行結(jié)果均不相同,產(chǎn)生這種問題的原因是多線程中同步共享問題導(dǎo)致的,即是多個(gè)線程同時(shí)共享了一個(gè)資源。如何解決上述問題,最簡單的方法就是使用靜態(tài)字段的ThreadStatic特性。

在定義靜態(tài)字段時(shí),加上[ThreadStatic]特性,如下:

代碼如下:
 [ThreadStatic]
static int num = 0;
兩個(gè)線程不變的情況下,再次運(yùn)行,結(jié)果如下:

 

不論運(yùn)行多少次,結(jié)果都是一樣的,當(dāng)字段被ThreadStatic特性修飾后,它的值在每個(gè)線程中都是不同的,即每個(gè)線程對static字段都會(huì)重新分配內(nèi)存空間,就當(dāng)然于一次new操作,這樣一來,由于static字段所產(chǎn)生的問題也就沒有了。

2. 資源共享

多線程的資源共享,也就是多線程同步(即資源同步),需要注意的是線程同步指的是線程所訪問的資源同步,并非是線程本身的同步。

在實(shí)際使用多線程的過程中,并非都是各個(gè)線程訪問不同的資源。

下面看一個(gè)線程示例,假如我們并不知道線程要多久完成,我們等待一個(gè)固定的時(shí)間(假如是500毫秒):

先定義一個(gè)靜態(tài)字段:

 static int result;
創(chuàng)建線程:

Thread myThread = new Thread(() =>
{
 Thread.Sleep(1000);
 result = 100;
});
myThread.Start();
Thread.Sleep(500); 
Console.WriteLine(result);

運(yùn)行結(jié)果如下:

 

可以看到結(jié)果是0,顯然不是我們想要的,但往往在線程執(zhí)行過程中,我們并不知道它要多久完成,能不能在線程完成后有一個(gè)通知?

這里有很多笨的方法,比如我們可能會(huì)想到使用一個(gè)循環(huán)來檢測線程狀態(tài),這些都不是理想的。

.NET為我們提供了一個(gè)Join方法,就是線程阻塞,可以解決上述問題,我們使用Stopwatch來記時(shí),

改進(jìn)線程代碼如下:

System.Diagnostics.Stopwatch watch = System.Diagnostics.Stopwatch.StartNew();
Thread myThread = new Thread(() =>
{
 Thread.Sleep(1000);
 result = 100;
});
myThread.Start();
Thread.Sleep(500);
myThread.Join();
Console.WriteLine(watch.ElapsedMilliseconds);
Console.WriteLine(result);

運(yùn)行結(jié)果如下:

 結(jié)果和我們想要的是一致的。

3. 線程鎖

除了上面示例的方法,對于線程同步,.NET還為我們提供了一個(gè)鎖機(jī)制來解決同步,再次改進(jìn)上面示例如下:

先定義一個(gè)靜態(tài)字段來存儲(chǔ)鎖:

static object locker = new object();
這里我們可以先不用考慮這個(gè)對象是什么。繼續(xù)看改進(jìn)后的線程:

System.Diagnostics.Stopwatch watch = System.Diagnostics.Stopwatch.StartNew();
Thread t1 = new Thread(() =>
{
 lock (locker)
 {
 Thread.Sleep(1000);
 result = 100;
 }
});
t1.Start();
Thread.Sleep(100);
lock (locker)
{
 Console.WriteLine("線程耗時(shí):"+watch.ElapsedMilliseconds);
 Console.WriteLine("線程
輸出:"+result); }

運(yùn)行結(jié)果如下:

運(yùn)行結(jié)果和上面示例一樣,如果線程處理過程較復(fù)雜,可以看到耗時(shí)明顯減少,這是一種用比阻塞更效率的方式完成線程同步。

4. 線程通知

前面說到了能否在一個(gè)線程完成后,通知等待的線程呢,這里.NET為我們提供了一個(gè)事件通知的方法來解決這個(gè)問題。

4.1 AutoResetEvent 

先定義一個(gè)通知對象

代碼如下:
 static EventWaitHandle tellMe = new AutoResetEvent(false);

改進(jìn)上面的線程如下:

System.Diagnostics.Stopwatch watch = System.Diagnostics.Stopwatch.StartNew();
Thread myThread = new Thread(() =>
{
 Thread.Sleep(1000);
 result = 100;
 tellMe.Set();
});
myThread.Start();
tellMe.WaitOne();
Console.WriteLine("線程耗時(shí):" + watch.ElapsedMilliseconds);
Console.WriteLine("線程
輸出:" + result);

 運(yùn)行結(jié)果如下:

4.2 ManualResetEvent

和AutoResetEvent 相對的還有一個(gè) ManualResetEvent 手動(dòng)模式,他們的區(qū)別在于,在線程結(jié)束后ManualResetEvent 還是可以通行的,除非手動(dòng)Reset關(guān)閉。下面看一個(gè)示例:

先定義一個(gè)手動(dòng)通知的對象:

static EventWaitHandle mre = new ManualResetEvent(false);


創(chuàng)建線程:

System.Diagnostics.Stopwatch watch = System.Diagnostics.Stopwatch.StartNew();
Thread myThreadFirst = new Thread(() =>
{
 Thread.Sleep(1000);
 result = 100;
 mre.Set();
}) { Name = "線程一" };
Thread myThreadSecond = new Thread(() =>
{
 mre.WaitOne();
 Console.WriteLine(Thread.CurrentThread.Name + "獲取結(jié)果:" + result + "("+System.DateTime.Now.ToString()+")");
}) { Name="線程二"};
myThreadFirst.Start();
myThreadSecond.Start();
mre.WaitOne();
Console.WriteLine("線程耗時(shí):" + watch.ElapsedMilliseconds + "(" + System.DateTime.Now.ToString() + ")");
Console.WriteLine("線程
輸出:" + result + "(" + System.DateTime.Now.ToString() + ")");

運(yùn)行結(jié)果如下:

4.3. Semaphore

Semaphore也是線程通知的一種,上面的通知模式,在線程開啟的數(shù)量很多的情況下,使用Reset()關(guān)閉時(shí),如果不使用Sleep休眠一下,很有可能導(dǎo)致某些線程沒有恢復(fù)的情況下,某一線程提前關(guān)閉,對于這種很難預(yù)測的情況,.NET提供了更高級(jí)的通知方式Semaphore,可以保證在超多線程時(shí)不會(huì)出現(xiàn)上述問題。

先定義一個(gè)通知對象的靜態(tài)字段:

代碼如下:
   static Semaphore sem = new Semaphore(2, 2);

使用循環(huán)創(chuàng)建100個(gè)線程:


for (int i = 1; i <= 100; i++)
{
 new Thread(() =>
 {
 sem.WaitOne();
 Thread.Sleep(30);
 Console.WriteLine(Thread.CurrentThread.Name+" "+DateTime.Now.ToString());
 sem.Release();
 }) { Name="線程"+i}.Start();
}

運(yùn)行結(jié)果如下:

 

可以看到完整的輸出我們所想要看到的結(jié)果。

5. 本節(jié)要點(diǎn):

A.線程中靜態(tài)字段的ThreadStatic特性,使用該字段在不同線程中擁有不同的值

B.線程同步的幾種方式,線程鎖和線程通知

C.線程通知的兩種方式:AutoResetEvent /ManualResetEvent  和 Semaphore

到此為止.net面向?qū)ο笾嗑€程(Multithreading)及多線程高級(jí)應(yīng)用介紹到此為止。

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

.net面向?qū)ο笾嗑€程(Multithreading)及 多線程高級(jí)應(yīng)用

.net面向?qū)ο笾嗑€程(Multithreading)及 多線程高級(jí)應(yīng)用:在.net面向?qū)ο蟪绦蛟O(shè)計(jì)階段在線程資源共享中的線程安全和線程沖突的解決方案;多線程同步,使用線程鎖和線程通知實(shí)現(xiàn)線程同步,具體內(nèi)容介紹如下: 1、 ThreadStatic特性 特性:[ThreadStatic] 功能:指定靜態(tài)字段在不同線程中擁有不同的值 在此之前,我們
推薦度:
  • 熱門焦點(diǎn)

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 一级久久 | 亚洲最大色网 | 日韩aa在线观看 | 国产在线视频资源 | 91精品久久久久 | xxxxx欧美| 亚洲一区二区三区精品视频 | 九九操视频 | 亚洲一区中文字幕在线观看 | 国产精品视频不卡 | 亚洲欧美在线综合 | 国产欧美日韩在线 | 91热成人精品国产免费 | 欧美激情免费观看一区 | 国产欧美一区二区三区在线 | 视频一区二区三区在线 | 青青草国产免费国产是公开 | 日本a级免费 | 亚洲欧美在线观看一区二区 | 香蕉久久精品 | 全黄a一级毛片 | 国产视频高清在线观看 | 久久久久免费精品国产小说 | 黄色国产网站 | 99精品高清视频一区二区 | 国产免费一区二区三区 | 午夜日本一区二区三区 | 国产精品毛片va一区二区三区 | 日本v片免费一区二区三区 欧洲精品欧美精品 | 亚洲欧美日韩国产色另类 | 日本一二区视频 | 久久久久久91精品色婷婷 | 亚洲欧美视频 | 狠狠操夜夜 | 欧美成人亚洲高清在线观看 | 九九爱精品视频 | 久久一区二区三区免费播放 | 亚洲午夜久久久久久久久电影网 | 国产精品亚洲精品观看不卡 | 国产女人在线视频 | 一区二区三区在线 |