一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

關(guān)于C#線程,線程池和并行運算的簡單使用和對比

前言:看了書上兩個使用C#4.0并行編程的demo,又對照以前收藏的網(wǎng)上幾篇講述線程池的雄文,一并整理,寫個示例總結(jié)一下。寫這篇文章的時候,發(fā)現(xiàn)關(guān)于線程的好幾個基礎(chǔ)的重要的知識點自己都不熟悉,而且可能習(xí)慣性認知淺薄,所以痛苦的無以復(fù)加,不知道到底要說什么。不想看文章的可以直接下載最后的示例,本文代碼主要參考Marc Clifton的“.NET's ThreadPool Class - Behind The Scenes”,對新手也許有幫助。

  參考:

  http://msdn.microsoft.com/zh-cn/library/system.threading.threadpool(VS.80).ASPx

  http://www.codeproject.com/KB/threads/threadtests.ASPx

  http://www.codeproject.com/KB/threads/smartthreadpool.ASPx

  http://blog.zhaojie.me/2009/07/thread-pool-1-the-goal-and-the-clr-thread-pool.html  (老趙的淺談線程池上中下三篇)

  先大概看一下控制臺應(yīng)用程序的Main方法的主要代碼:

        static bool done = false;
static decimal count2 = 0;
static int threadDone = 0;//標志啟用線程數(shù)?
static System.Timers.Timer timer = new System.Timers.Timer(1000);

static decimal[] threadPoolCounters = new decimal[10];
static Thread[] threads = new Thread[10];
static System.Timers.Timer[] threadTimers = new System.Timers.Timer[10];

static void Main(string[] args)
{
timer.Stop();
/*當 AutoReset 設(shè)置為 false 時,Timer 只在第一個 Interval 過后引發(fā)一次 Elapsed 事件。
若要保持以 Interval 時間間隔引發(fā) Elapsed 事件,請將 AutoReset 設(shè)置為 true。
*/
timer.AutoReset
= false;
timer.Elapsed
+= new ElapsedEventHandler(OnTimerEvent);//當timer.Start()時,觸發(fā)事件
decimal total = 0;

// raw test
decimal count1 = SingleThreadTest();//單一線程,一跑到底
Console.WriteLine("Single thread count = " + count1.ToString());

// create one thread, increment counter, destroy thread, repeat
Console.WriteLine();
CreateAndDestroyTest();
//創(chuàng)建一個線程,運算,然后銷毀該線程 重復(fù)前面的動作
Console.WriteLine("Create and destroy per count = " + count2.ToString());

// Create 10 threads and run them simultaneously
//一次性創(chuàng)建10個線程,然后遍歷使線程執(zhí)行運算
Console.WriteLine();
InitThreadPoolCounters();
InitThreads();
StartThreads();
while (threadDone != 10) { };
Console.WriteLine(
"10 simultaneous threads:");
for (int i = 0; i < 10; i++)
{
Console.WriteLine(
"T" + i.ToString() + " = " + threadPoolCounters[i].ToString() + " ");
total
+= threadPoolCounters[i];
}
Console.WriteLine(
"Total = " + total.ToString());
Console.WriteLine();

Console.WriteLine(
"///////////////////////////////////////////////////");

// using ThreadPool
//直接通過線程池的QueueUserWorkItem方法,按隊列執(zhí)行10個任務(wù)
Console.WriteLine();
Console.WriteLine(
"ThreadPool:");
InitThreadPoolCounters();
QueueThreadPoolThreads();
while (threadDone != 10) { };
Console.WriteLine(
"ThreadPool: 10 simultaneous threads:");
total
= 0;
for (int i = 0; i < 10; i++)
{
// threadTimers[i].Stop();
// threadTimers[i].Dispose();
Console.WriteLine("T" + i.ToString() + " = " + threadPoolCounters[i].ToString() + " ");
total
+= threadPoolCounters[i];
}
Console.WriteLine(
"Total = " + total.ToString());

// using SmartThreadPool
//通過Amir Bar的SmartThreadPool線程池,利用QueueUserWorkItem方法,按隊列執(zhí)行10個任務(wù)
Console.WriteLine();
Console.WriteLine(
"SmartThreadPool:");
InitThreadPoolCounters();
QueueSmartThreadPoolThreads();
while (threadDone != 10) { };
Console.WriteLine(
"SmartThreadPool: 10 simultaneous threads:");
total
= 0;
for (int i = 0; i < 10; i++)
{
Console.WriteLine(
"T" + i.ToString() + " = " + threadPoolCounters[i].ToString() + " ");
total
+= threadPoolCounters[i];
}
Console.WriteLine(
"Total = " + total.ToString());

// using ManagedThreadPool
//通過Stephen Toub改進后的線程池,利用QueueUserWorkItem方法,按隊列執(zhí)行10個任務(wù)
Console.WriteLine();
Console.WriteLine(
"ManagedThreadPool:");
InitThreadPoolCounters();
QueueManagedThreadPoolThreads();
while (threadDone != 10) { };
Console.WriteLine(
"ManagedThreadPool: 10 simultaneous threads:");
total
= 0;
for (int i = 0; i < 10; i++)
{
Console.WriteLine(
"T" + i.ToString() + " = " + threadPoolCounters[i].ToString() + " ");
total
+= threadPoolCounters[i];
}
Console.WriteLine(
"Total = " + total.ToString());

// using C#4.0 Parallel
//通過Tasks.Parallel.For進行并行運算
Console.WriteLine();
Console.WriteLine(
"Parallel:");
InitThreadPoolCounters();
UseParallelTasks();
while (threadDone != 10) { };
Console.WriteLine(
"Parallel: 10 simultaneous threads:");
total
= 0;
for (int i = 0; i < 10; i++)
{
Console.WriteLine(
"T" + i.ToString() + " = " + threadPoolCounters[i].ToString() + " ");
total
+= threadPoolCounters[i];
}
Console.WriteLine(
"Total = " + total.ToString());
}

NET技術(shù)關(guān)于C#線程,線程池和并行運算的簡單使用和對比,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 久久久噜噜噜久久久 | 综合网视频| 日本午夜vr影院新入口 | 国产91精品福利在线观看 | 白白在线成人永久视频 | 在线观看www视频 | 午夜视频精品 | 色久激情 | 怡红院美国十次成人影院 | 国产精品免费一区二区三区四区 | 精品久久久噜噜噜久久7 | 97成人在线| 亚洲视频网站在线观看 | 一色屋色费精品视频在线看 | 国产在线看不卡一区二区 | 色婷五月天| 激情视频激情图片激情小说 | 精品久久久久久中文字幕 | 国产成人精品一区二三区在线观看 | 久久99精品久久久久久青青91 | 激情小说区 | 2021成人国产精品 | 免费成人午夜视频 | 热99re久久精品2久久久 | 欧美在线观看黄色 | 99爱精品视频 | 国产高清视频免费 | 国产成人精品福利网站在线观看 | 午夜一级在线 | 国产aⅴ精品一区二区三区久久 | 亚洲青草 | 亚洲合集 | 激情小说图 | 久久亚洲国产成人亚 | 91久久青草精品38国产 | 久久久精品久久 | 日韩麻豆 | 91精品国产综合久久消防器材 | 风间由美一区二区播放合集 | 最新97超级碰碰碰碰久久久久 | 国产午夜免费视频片夜色 |