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

.NET中線程的生命周期

開發 后端
我們今天要談談.NET中線程的生命周期。當我們創建一個線程后,我們需要調用線程對象的Start()方法來調度那個線程。

  當一個線程計劃執行時它可以經過幾個狀態,包括未開始,活躍,睡眠,等等。線程類包含幾個允許你啟動、停止、恢復、退出、暫停以及等待一個線程的方法。我們可以使用ThreadState屬性來獲取線程的當前狀態,狀態值可能是ThreadState枚舉中的一個:

  Aborted - 線程當前處理停止狀態,但是不一定已經執行完。

  AbortRequested – 已經調用Abort() 方法但是線程還沒有接收到將試圖終止線程的System.Threading.ThreadAbortexception。雖然線程還沒有停止,但是馬上就會。

  Background - 線程在后臺執行。

  Running - 線程已經啟動而且沒有被阻塞。

  Stopped - 線程已經完成了所有指令并停止了。

  StopRequested - 請求線程停止。

  Suspend - 線程已經被掛起。

  SuspendRequested - 請求掛起線程。

  Unstarted - 線程還沒有調用Start()方法之前。

  WaitSleepJoin - 調用Wait(), Sleep() 或 Join() 方法后處理阻塞狀態的線程。

  圖3 顯示了一個線程的生命周期。

圖3

  在這部分,我們將討論線程的生命周期

  讓一個線程進入睡眠狀態

  當我們創建一個線程后,我們需要調用線程對象的Start()方法來調度那個線程。在這時,CLR將會為作為構造函數參數傳遞給線程對象的方法地址分配一個時間片。一旦線程開始執行,它就可以在操作系統處理其他線程時回到睡眠狀態或者退出狀態。我們可以使用線程類的Sleep()方法讓一個線程進入睡眠狀態。如果你正在等待一個資源并且你想在稍后繼續嘗試訪問這個資源時,Sleep()方法是很重要的。舉個例子,假設你的程序由于無法訪問需要的資源而導致其不能繼續執行時,你可能想要在幾毫秒之后嘗試繼續訪問資源,在這種情況下讓線程在再次嘗試訪問資源之前睡眠一段時間是一個很好的方式。

  Sleep()方法有兩種重載方式。第一種重載方法有一個整型參數,并會按照指定的毫秒時間暫停線程執行。例如,如果你向線程傳遞值100,那么線程將會暫停100毫秒。這個方法將會讓線程進入WaitSleepJoin狀態。讓我們看一個例子,thread_sleep2.cs:

  1. /*************************************  
  2.   /* Copyright (c) 2012 Daniel Dong  
  3.   *  
  4.   * Author:Daniel Dong  
  5.   * Blog: www.cnblogs.com/danielWise  
  6.   * Email: guofoo@163.com  
  7.   *  
  8.   */ 
  9.   using System;  
  10.   using System.Collections.Generic;  
  11.   using System.Text;  
  12.   using System.Threading;  
  13.   namespace SimpleThread  
  14.   {  
  15.   public class ThreadSleep  
  16.   {  
  17.   public static Thread worker;  
  18.   public static Thread worker2;  
  19.   public static void Main()  
  20.   {  
  21.   Console.WriteLine("Entering the void Main!");  
  22.   worker = new Thread(new ThreadStart(Counter));  
  23.   worker2 = new Thread(new ThreadStart(Counter2));  
  24.   //Make the worker2 Object as highest priority  
  25.   worker2.Priority = ThreadPriority.Highest;  
  26.   worker.Start();  
  27. worker2.Start();  
  28.   Console.WriteLine("Exiting the void Main!");  
  29.   Console.ReadLine();  
  30.   }  
  31.  public static void Counter()  
  32.   {  
  33.   Console.WriteLine("Entering Counter");  
  34.   for (int i = 1; i <50; i++)  
  35.   {  
  36.   Console.Write(i + " ");  
  37.   if (i == 10)  
  38.   {  
  39.   Console.WriteLine();  
  40.   Thread.Sleep(1000);  
  41.   }  
  42.   }  
  43.   Console.WriteLine("Exiting Counter");  
  44.   }  
  45.   public static void Counter2()  
  46.   {  
  47.   Console.WriteLine("Entering Counter2");  
  48.   for (int i = 51; i <100; i++)  
  49.   {  
  50.   Console.Write(i + " ");  
  51.   if (i == 70)  
  52.   {  
  53.   Console.WriteLine();  
  54.   Thread.Sleep(5000);  
  55.  }  
  56.   }  
  57.   Console.WriteLine("Exiting Counter2");  
  58.   }  
  59.   }  
  60.   } 

 

  Counter()方法從1到50計數,當到達10以后睡眠1000毫秒。Counter2()方法從51~100計數,當到達70時睡眠5000毫秒。下面是輸出結果:

注:以上是在多核CPU下運行的結果,單核CPU 執行情況可能與上圖有所出入。

  第二種重載方法有一個TimeSpan類型參數,當前線程會按照TimeSpan的值暫停一段時間。TimeSpan是System命名空間中的一個類。TimeSpan有一些很有用的屬性并會返回基于時鐘時間間隔。

  我們可以使用FromSeconds()和FromMinutes()來確定睡眠時間。下面是一個例子,thread_sleep3.cs:

 

  1.   public static void Counter()  
  2.   {  
  3.   Console.WriteLine("Entering Counter");  
  4.   for (int i = 1; i <50; i++)  
  5.   {  
  6.   Console.Write(i + " ");  
  7.   if (i == 10)  
  8.   {  
  9.   Console.WriteLine();  
  10.   Thread.Sleep(TimeSpan.FromSeconds(1));  
  11.  }  
  12.   }  
  13.   Console.WriteLine("Exiting Counter");  
  14.   }  
  15.   public static void Counter2()  
  16.   {  
  17.   Console.WriteLine("Entering Counter2");  
  18.   for (int i = 51; i <100; i++)  
  19.   {  
  20.  Console.Write(i + " ");  
  21.   if (i == 70)  
  22.   {  
  23.   Console.WriteLine();  
  24.   Thread.Sleep(TimeSpan.FromSeconds(5));  
  25.   }  
  26.   }  
  27.   Console.WriteLine("Exiting Counter2");  
  28.   } 

 

  輸出結果與thread_sleep2類似。

  中斷一個線程

  當讓一個線程睡眠時,它實際會進入WaitSleepJoin狀態。如果線程處理睡眠狀態,那么在它超時退出之前唯一可以喚醒線程的方式是使用Interrupt()方法。Interrupt()方法將讓線程回到調度隊列中去。讓我們看一個例子,thread_interrupt.cs:

 

  1.   /*************************************  
  2.   /* Copyright (c) 2012 Daniel Dong  
  3.   *  
  4.   * Author:Daniel Dong  
  5.   * Blog: www.cnblogs.com/danielWise  
  6.   * Email: guofoo@163.com  
  7.   *  
  8.   */ 
  9.   using System;  
  10.   using System.Collections.Generic;  
  11.   using System.Text;  
  12.   using System.Threading;  
  13.  namespace SimpleThread  
  14.   {  
  15.   public class Interrupt  
  16.   {  
  17.   public static Thread sleeper;  
  18.   public static Thread worker;  
  19.   public static void Main()  
  20.   {  
  21.   Console.WriteLine("Entering the void Main!");  
  22.   sleeper = new Thread(new ThreadStart(SleepingThread));  
  23.   worker = new Thread(new ThreadStart(AwakeThread));  
  24.   sleeper.Start();  
  25.   worker.Start();  
  26.   Console.WriteLine("Exiting the void Main!");  
  27.   Console.ReadLine();  
  28.   }  
  29.  public static void SleepingThread()  
  30.   {  
  31.   for (int i = 1; i <50; i++)  
  32.   {  
  33.   Console.Write(i + " ");  
  34.   if (i == 10 || i == 20 || i == 30)  
  35.   {  
  36.   Console.WriteLine("Going to sleep at: " + i);  
  37.   try 
  38.   {  
  39.   Thread.Sleep(20);  
  40.   }  
  41.   catch (ThreadInterruptedException ex)  
  42.   {  
  43.   Console.WriteLine(ex.Message);  
  44.   }  
  45.  }  
  46.   }  
  47.   }  
  48.   public static void AwakeThread()  
  49.   {  
  50.   for (int i = 51; i <100; i++)  
  51.   {  
  52.   Console.Write(i + " ");  
  53.   if (sleeper.ThreadState == ThreadState.WaitSleepJoin)  
  54.   {  
  55.   Console.WriteLine("Interrupting the sleeping thread.");  
  56.   sleeper.Interrupt();  
  57.   }  
  58.   }  
  59.   }  
  60.   }  
  61.   } 

 

  在上面的例子中,當計數器的值為10, 20 和 30 時第一個線程會睡眠。第二個線程會檢查第一個線程是否已經進入睡眠狀態。如果是的話,它將中斷第一個線程并使它回到調度隊列中去。Interrupt()方法是讓睡眠線程重新醒來的最好方式,當線程等待的資源可用且你想讓線程繼續運行時你可以使用這個方法。輸出結果與下面顯示的類似:

原文鏈接:http://www.cnblogs.com/danielWise/archive/2012/01/15/2323084.html

【編輯推薦】

  1. .NET 4多核并行中的Task優化線程池
  2. .NET跨線程控件的相關操作
  3. 詳解.NET多線程異常的處理方法
  4. 講述ADO多線程如何更好的進行操作
責任編輯:彭凡 來源: 博客園
相關推薦

2023-10-26 08:25:35

Java線程周期

2010-07-14 10:48:37

Perl線程

2013-08-19 17:03:00

.Net生命周期對象

2009-06-18 13:32:39

Java線程生命周期

2009-07-23 10:23:44

2009-06-29 18:03:15

Java多線程線程的生命周期

2010-07-14 10:59:15

Perl線程

2015-07-08 16:28:23

weak生命周期

2009-07-20 10:33:02

ASP.NET MVC

2013-04-07 10:42:56

Asp.Net頁面周期

2009-07-23 18:14:17

MVC生命周期

2022-04-19 07:20:24

軟件開發安全生命周期SSDLC應用安全

2009-07-31 17:53:39

ASP.NET線程安全

2009-08-04 17:49:31

Web Page生命周ASP.NET Pos

2009-08-04 16:05:15

ASP.NET頁面生命

2009-08-04 16:50:15

ASP.NET頁面生命

2009-07-31 10:47:18

ASP.NET頁面生命

2009-06-11 11:28:35

JSF生命周期

2009-02-12 13:16:55

請求生命周期MVCASP.NET

2010-01-15 13:52:44

VB.NET對象生命周
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 偷派自拍 | 欧美一区二区三区四区在线 | 国产精品五月天 | 先锋资源在线 | 亚洲一区二区中文字幕 | 亚洲综合色视频在线观看 | 午夜精品视频在线观看 | 久久久久久久成人 | 亚洲精品中文字幕 | 在线综合视频 | 欧美专区在线视频 | 嫩草视频在线 | 国产精品久久久久久吹潮 | 天天草夜夜骑 | 美女天天操 | 亚洲www | 久久精品国产久精国产 | 综合色播 | 国产精品久久免费观看 | 成人激情免费视频 | 国产精品久久一区二区三区 | 爽爽免费视频 | 中文字幕乱码视频32 | 亚洲精品乱码久久久久久久久 | 成人伊人 | 成人不卡| 亚洲国产免费 | 一区二区国产在线观看 | 欧美在线视频网 | 91麻豆精品国产91久久久久久久久 | 91精品麻豆日日躁夜夜躁 | 日韩中文一区二区三区 | 最近中文字幕第一页 | 久久久久久国产精品mv | 日韩中文字幕一区二区 | 欧美日韩国产不卡 | 免费观看黄a一级视频 | 精品日韩一区 | 在线免费观看毛片 | 成人av一区 | 精品国产乱码久久久久久闺蜜 |