C#多线程管理代码
/// <summary> /// 多线程执行 /// </summary> public class MultiThreadingWorker { /// <summary> /// 确保线程全部完成 /// </summary> private Done m_done = null; private long m_startTime = 0; private Queue m_workload = null; public MultiThreadingWorker() { m_done = new Done(); m_workload = new Queue(); } /// <summary> /// 线程工作的内容委托 /// </summary> public WorkContent workContent { get; set; } /// <summary> /// 线程数目 /// </summary> public int threadCount { get; set; } private bool m_quit; public bool Quit { get { return m_quit; } set { m_quit = value; } } /// <summary> /// 增加工作的对象到队列 /// </summary> /// <param name="work"></param> public void AddWork(Object work) { Monitor.Enter(this); m_workload.Enqueue(work); Monitor.Pulse(this); Monitor.Exit(this); } /// <summary> /// 从队列中取出对象 /// </summary> /// <returns></returns> private Object ObtainWork() { Monitor.Enter(this); while (m_workload.Count < 1) { Monitor.Wait(this); } Object next = m_workload.Dequeue(); Monitor.Exit(this); return next; } /// <summary> /// 开始执行 /// </summary> public void Start() { m_startTime = System.DateTime.Now.Ticks; m_done.Reset(); m_quit = false; for (int i = 1; i <= threadCount; i++) { ThreadStart ts = new ThreadStart(this.Process); Thread m_thread = new Thread(ts); m_thread.Start(); } m_done.WaitBegin(); m_done.WaitDone(); } /// <summary> /// 停止执行 /// </summary> public void Stop() { m_quit = true; } private void Process() { while (m_quit==false) { Object workobj = ObtainWork(); m_done.WorkerBegin(); try { workContent(workobj); } catch (Exception e) { System.Console.WriteLine(" Error:" + e.Message); } finally { m_done.WorkerEnd(); } } } } /// <summary> /// 执行内容适用委托 /// </summary> /// <param name="work"></param> public delegate void WorkContent(Object work); public class Done { private int m_activeThreads = 0; private bool m_started = false; public void WaitDone() { Monitor.Enter(this); while ( m_activeThreads>0 ) { Monitor.Wait(this); } Monitor.Exit(this); } public void WaitBegin() { Monitor.Enter(this); while ( !m_started ) { Monitor.Wait(this); } Monitor.Exit(this); } /// <summary> /// 执行开始 /// </summary> public void WorkerBegin() { Monitor.Enter(this); m_activeThreads++; m_started = true; Monitor.Pulse(this); Monitor.Exit(this); } /// <summary> /// 执行完成 /// </summary> public void WorkerEnd() { Monitor.Enter(this); m_activeThreads--; Monitor.Pulse(this); Monitor.Exit(this); } /// <summary> /// 重新初始化 /// </summary> public void Reset() { Monitor.Enter(this); m_activeThreads = 0; Monitor.Exit(this); } }
调用代码:
public class TestMultiThreading { public static void Test() { MultiThreadingWorker thWork = new MultiThreadingWorker(); thWork.threadCount = 20; thWork.workContent = new WorkContent(WorkFun); for (int i = 0; i < 100; i++) thWork.AddWork(i); thWork.Start(); } private static void WorkFun(object obj) { Console.WriteLine("执行内容:" + obj.ToString()); } }
分类:
AppFrameWork框架
标签:
多线程
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· [AI/GPT/综述] AI Agent的设计模式综述