欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

Winform中C#線程控制的常見情況有哪些

本篇內(nèi)容主要講解“Winform中C#線程控制的常見情況有哪些”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Winform中C#線程控制的常見情況有哪些”吧!

創(chuàng)新互聯(lián)專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于網(wǎng)站設(shè)計、成都網(wǎng)站設(shè)計、彭澤網(wǎng)絡(luò)推廣、小程序設(shè)計、彭澤網(wǎng)絡(luò)營銷、彭澤企業(yè)策劃、彭澤品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運營等,從售前售中售后,我們都將竭誠為您服務(wù),您的肯定,是我們最大的嘉獎;創(chuàng)新互聯(lián)為所有大學生創(chuàng)業(yè)者提供彭澤建站搭建服務(wù),24小時服務(wù)熱線:13518219792,官方網(wǎng)址:aaarwkj.com

Winform界面中,將事務(wù)放在新開的線程中操作是十分有用的做法,因為這樣可以增加用戶體驗,減少耗時。對這些C#線程的控制,常常有下面這四種情況:

1. 啟動線程;

2. 線程間通訊;

3. 線程終止;

4. 線程中的異常處理;

下面總結(jié)一些上面這些C#線程操作的常用方法。

C#線程控制1. 啟動C#線程

◆如果是需要很頻繁的開線程,會使用線程池(微軟的或自己寫的)

◆Thread.Start(參數(shù)object);

◆或者用對象提供的BeginXXXX()這種都是異步,也算多線程啟動.

C#線程控制2. C#線程間通訊

◆委托,事件這些比較常用,并且對object的多線程處理需要謹慎,可能用到lock(object){}.

◆主要是通過線程同步或者回調(diào)方法(或者說是委托)來實現(xiàn)

C#線程控制3. 線程終止

◆線程的終止,用事件AUTORESET之類

◆可以用Thread.ManualEvent().Reset()/Set()/WaitOne()方法來判斷和等待

C#線程控制4. 線程中的異常處理

◆線程中的異常通過事件傳回到主線程處理

◆還是寫log吧,多線程debug比較難,還是逐步log比較好.

用于C#線程通訊的lock關(guān)鍵字

下面的示例演示使用 lock 關(guān)鍵字以及 AutoResetEvent 和 ManualResetEvent 類對主線程和兩個輔助線程進行線程同步。

該示例創(chuàng)建兩個輔助線程。一個線程生成元素并將它們存儲在非線程安全的泛型隊列中。有關(guān)更多信息,請參見 Queue。另一個線程使用此隊列中的項。另外,主線程定期顯示隊列的內(nèi)容,因此該隊列被三個線程訪問。lock 關(guān)鍵字用于同步對隊列的訪問,以確保隊列的狀態(tài)沒有被破壞。

除了用 lock 關(guān)鍵字來阻止同時訪問外,還用兩個事件對象提供進一步的同步。一個事件對象用來通知輔助線程終止,另一個事件對象由制造者線程用來在有新項添加到隊列中時通知使用者線程。這兩個事件對象封裝在一個名為 SyncEvents 的類中。這使事件可以輕松傳遞到表示制造者線程和使用者線程的對象。SyncEvents 類是按如下方式定義的:

C# code

using System;   using System.Threading;   using System.Collections;   using System.Collections.Generic;    public class SyncEvents   {   public SyncEvents()   {    _newItemEvent = new AutoResetEvent(false);   _exitThreadEvent = new ManualResetEvent(false);   _eventArray = new WaitHandle[2];   _eventArray[0] = _newItemEvent;   _eventArray[1] = _exitThreadEvent;   }    public EventWaitHandle ExitThreadEvent   {   get { return _exitThreadEvent; }   }   public EventWaitHandle NewItemEvent   {   get { return _newItemEvent; }   }   public WaitHandle[] EventArray   {   get { return _eventArray; }   }    private EventWaitHandle _newItemEvent;   private EventWaitHandle _exitThreadEvent;   private WaitHandle[] _eventArray;   }   public class Producer   {   public Producer(Queue <int> q, SyncEvents e)   {   _queue = q;   _syncEvents = e;   }   // Producer.ThreadRun   public void ThreadRun()   {   int count = 0;   Random r = new Random();   while (!_syncEvents.ExitThreadEvent.WaitOne(0, false))   {   lock (((ICollection)_queue).SyncRoot)   {   while (_queue.Count < 20)   {   _queue.Enqueue(r.Next(0,100));   _syncEvents.NewItemEvent.Set();   count++;   }   }   }   Console.WriteLine("Producer thread: produced {0} items", count);   }   private Queue <int> _queue;   private SyncEvents _syncEvents;   }    public class Consumer   {   public Consumer(Queue <int> q, SyncEvents e)   {   _queue = q;   _syncEvents = e;   }   // Consumer.ThreadRun   public void ThreadRun()   {   int count = 0;   while (WaitHandle.WaitAny(_syncEvents.EventArray) != 1)   {   lock (((ICollection)_queue).SyncRoot)   {   int item = _queue.Dequeue();   }   count++;   }   Console.WriteLine("Consumer Thread: consumed {0} items", count);   }   private Queue <int> _queue;   private SyncEvents _syncEvents;   }    public class ThreadSyncSample   {   private static void ShowQueueContents(Queue <int> q)   {   lock (((ICollection)q).SyncRoot)   {   foreach (int item in q)   {   Console.Write("{0} ", item);   }   }   Console.WriteLine();   }    static void Main()   {   Queue <int> queue = new Queue <int>();   SyncEvents syncEvents = new SyncEvents();    Console.WriteLine("Configuring worker threads...");   Producer producer = new Producer(queue, syncEvents);   Consumer consumer = new Consumer(queue, syncEvents);   Thread producerThread = new Thread(producer.ThreadRun);   Thread consumerThread = new Thread(consumer.ThreadRun);    Console.WriteLine("Launching producer and consumer threads...");  producerThread.Start();   consumerThread.Start();    for (int i=0; i <4; i++)   {   Thread.Sleep(2500);   ShowQueueContents(queue);   }    Console.WriteLine("Signaling threads to terminate...");   syncEvents.ExitThreadEvent.Set();    producerThread.Join();   consumerThread.Join();   }    }

到此,相信大家對“Winform中C#線程控制的常見情況有哪些”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進入相關(guān)頻道進行查詢,關(guān)注我們,繼續(xù)學習!

名稱欄目:Winform中C#線程控制的常見情況有哪些
地址分享:http://aaarwkj.com/article28/ijhhjp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計、網(wǎng)站營銷、網(wǎng)站改版、微信小程序、品牌網(wǎng)站制作標簽優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

商城網(wǎng)站建設(shè)
欧美日本道一区二区三区| av网址不卡在线免费观看| 国产欧美日本一区二区| 国产精品麻豆一区二区三区| 精品一区二区视频在线观看网站| 一区二区三区日韩欧美在线| 久久精品国产精品日韩欧美| 国产成人午夜视频免费一区| 免费观看国产性生活片| 国产麻豆成人传媒免费观看| 女人天堂网av免费看| 亚洲中文有码在线播放| 国产乱子一区二区三区| 欧美日韩激情中文字幕| 亚洲一区二区日本久久| 日韩日韩毛片日韩毛片| 婷婷不卡中文字幕三区| 亚洲成人免费电影91| 日本高清视频免费一区| 午夜福利在线视频观看| 免费国产成人在线视频| 欧美激情网页一区三区| 思思久久96热在精品国产| 日本加勒比系列在线播放| 欧美日韩亚洲视频二区| 日本三级黄色免费的网站| 蜜臀av中文字幕在线| 亚洲码与欧洲码一二三| 一区二区三区在线观看美女视频 | 精品久久久久久亚洲野狼| 免费一区二区不卡去日本| 国产69精品久久久久久人| 十八禁真人无摭挡观看| 熟女自拍偷拍视频播放| 日本久久高清免费观看| 九色综合一区二区三区| 午夜午色夜之日本福利片| 91九色在线视频观看| 中文字幕国产精品专区| 成人一区二区三区乱码| 国产av午夜精品福利|