自定义线程池-c#的简单实现

下面是代码,希望大家提出更好的建议:

1.ThreadManager.cs

using System;

using System.Threading;

using System.Collections;

namespace CustomThreadPool

{

///<summary>

///线程管理器,会开启或唤醒一个线程去执行指定的回调方法

///</summary>

public class ThreadManager

{

//线程列表,静态

private static ArrayList threadList = new ArrayList();

//不允许创建实例

private ThreadManager()

{

}

///<summary>

///静态方法,开启或唤醒一个线程去执行指定的回调方法

///</summary>

///<param name="waitCallback">委托实例</param>

///<param name="obj">传递给回调方法的参数</param>

///<param name="timeOut">当没有可用的线程时的等待时间,

///以毫秒为单位</param>

///<returns></returns>

public static bool QueueUserWorkItem(WaitCallback waitCallback,

Object obj, int timeOut)

{

//锁住共享资源,实现线程安全

lock(threadList)

{

try

{

//如果线程列表为空,填充线程列表

if (threadList.Count == 0)

{

InitThreadList();

}

long startTime = DateTime.Now.Ticks;

do

{

//遍历线程列表,找出可用的线程

foreach(MyThread myThread in threadList)

{

//线程为空,需要创建线程

if (myThread.T == null)

{

myThread.Start(waitCallback, obj, false);

return true;

}

else if (myThread.T.ThreadState ==
                                     ThreadState.Suspended)

{//线程为挂起状态,唤醒线程

myThread.Start(waitCallback, obj, true);

return true;

}

}

//在线程 Sleep 前释放锁

Monitor.PulseAll(threadList);

Thread.Sleep(500);

}

while (((DateTime.Now.Ticks - 
                        startTime) / 10000) < timeOut);

}

finally

{

Monitor.Exit(threadList);

}

}

return false;

}

//使用 MyThread 对象填充线程列表,注意,这个时候线程并没有启动

private static void InitThreadList()

{

threadList = new ArrayList();

for (int i = 0; i < 10; i++)

{

MyThread t = new MyThread();

threadList.Add(t);

}

}

}

}

2.MyThread.cs

using System;

using System.Threading;

namespace CustomThreadPool

{

///<summary>

///封装 .NET 框架提供的 Thread

///</summary>

internal class MyThread

{

//线程

private Thread t;

//委托,这里直接用 .NET 框架自带的,

//也可以根据需要自己定义一个

private WaitCallback w;

//传递给符合委托的回调方法的参数值,

//根据委托的定义而定

private Object o;

///<summary>

///执行回调方法的线程

///</summary>

public Thread T

{

get

{

return t;

}

}

public MyThread()

{

}

///<summary>

///开启新线程或唤醒线程,去执行回调方法

///</summary>

///<param name="w">用回调方法实例化了的委托实例</param>

///<param name="o">传递给回调方法的参数值</param>

///<param name="isSuspend">true 表示线程为挂起状态,

///false 则表示线程还没创建</param>

public void Start(WaitCallback w, Object o, bool isSuspend)

{

//开启新线程或唤醒线程前,先设置

this.w = w;

this.o = o;

//线程为挂起状态,唤醒线程继续执行

if (isSuspend)

{

t.Resume();

}

else

{//线程还没有创建,创建一个新线程,并执行

t = new Thread(new ThreadStart(this.ThreadProc));

t.Start();

}

}

///<summary>

///线程执行的方法

///</summary>

private void ThreadProc()

{

//死循环,使线程唤醒后不是退出,而是继续通过委托执行回调方法

while (true)

{

//通过委托执行回调方法

w(o);

t.Suspend();

}

}

}

}

3.Test.cs

using System;

using System.Threading;

namespace CustomThreadPool

{

///<summary>

///测试自定义线程池

///</summary>

class Test

{

///<summary>

///应用程序的主入口点。

///</summary>

[STAThread]

static void Main(string[] args)

{

//

// TODO: 在此处添加代码以启动应用程序

//

for (int i = 0; i < 5; i++)

{

Console.WriteLine("Start thread {0}", i.ToString());

Thread t = new Thread(new ThreadStart(WorkThread));

t.Start();

}

Console.ReadLine();

Thread.CurrentThread.Abort();

}

public static void WorkThread()

{

for (int i = 0; i < 10; i++)

{

if (i % 2 == 0)

{

if (!ThreadManager.QueueUserWorkItem(

new WaitCallback(ThreadProcOne), i, 2000))

{

Console.WriteLine("Failed" + i.ToString());

}

}

else

{

if (!ThreadManager.QueueUserWorkItem(

new WaitCallback(ThreadProcTwo), i, 2000))

{

Console.WriteLine("Failed" + i.ToString());

}

}

}

Thread.CurrentThread.Abort();

}

public static void ThreadProcOne(Object stateInfo)

{

Console.WriteLine("Test custom threadpool:"

+ ((int)stateInfo).ToString());

}

public static void ThreadProcTwo(Object stateInfo)

{

Console.WriteLine("Change work:"

+ ((int)stateInfo).ToString());

}

}

}

C#自定义线程池的更多相关文章

  1. Android线程管理之ThreadPoolExecutor自定义线程池

    前言: 上篇主要介绍了使用线程池的好处以及ExecutorService接口,然后学习了通过Executors工厂类生成满足不同需求的简单线程池,但是有时候我们需要相对复杂的线程池的时候就需要我们自己 ...

  2. Android AsyncTask 深度理解、简单封装、任务队列分析、自定义线程池

    前言:由于最近在做SDK的功能,需要设计线程池.看了很多资料不知道从何开始着手,突然发现了AsyncTask有对线程池的封装,so,就拿它开刀,本文将从AsyncTask的基本用法,到简单的封装,再到 ...

  3. Android 自定义线程池的实战

    前言:在上一篇文章中我们讲到了AsyncTask的基本使用.AsyncTask的封装.AsyncTask 的串行/并行线程队列.自定义线程池.线程池的快速创建方式. 对线程池不了解的同学可以先看 An ...

  4. c#网络通信框架networkcomms内核解析之十 支持优先级的自定义线程池

    NetworkComms网络通信框架序言 本例基于networkcomms2.3.1开源版本  gplv3协议 如果networkcomms是一顶皇冠,那么CommsThreadPool(自定义线程池 ...

  5. 介绍开源的.net通信框架NetworkComms框架 源码分析(十五 ) CommsThreadPool自定义线程池

    原文网址: http://www.cnblogs.com/csdev Networkcomms 是一款C# 语言编写的TCP/UDP通信框架  作者是英国人  以前是收费的 目前作者已经开源  许可是 ...

  6. 一个自定义线程池的小Demo

    在项目中如果是web请求时候,IIS会自动分配一个线程来进行处理,如果很多个应用程序共享公用一个IIS的时候,线程分配可能会出现一个问题(当然也是我的需求造成的) 之前在做项目的时候,有一个需求,就是 ...

  7. JAVA并发,线程工厂及自定义线程池

    package com.xt.thinks21_2; import java.util.concurrent.ExecutorService; import java.util.concurrent. ...

  8. java多线程(四)-自定义线程池

    当我们使用 线程池的时候,可以使用 newCachedThreadPool()或者 newFixedThreadPool(int)等方法,其实我们深入到这些方法里面,就可以看到它们的是实现方式是这样的 ...

  9. spring boot / cloud (四) 自定义线程池以及异步处理@Async

    spring boot / cloud (四) 自定义线程池以及异步处理@Async 前言 什么是线程池? 线程池是一种多线程处理形式,处理过程中将任务添加到队列,然后在创建线程后自动启动这些任务.线 ...

随机推荐

  1. sql截取数据库数字字段内容

    round(columnName, precision) 四舍五入 trunc(columnName, precision) 强制截断

  2. java 判断字符串是否为乱码

    import java.util.regex.Matcher; import java.util.regex.Pattern; public class MessyCodeCheck { public ...

  3. linux之cut用法

    转载:http://www.cnblogs.com/dong008259/archive/2011/12/09/2282679.html cut是一个选取命令,就是将一段数据经过分析,取出我们想要的. ...

  4. android自动化(2)

    使用monkeyrunner 自动化删除程序的时候出现如下错误 在任务管理器卸载android adb,Ok..然后再次使用的时候就出现这个问题, Try below steps: Close the ...

  5. Ubuntu 使用apt-get时提示错误:无法获得锁 /var/lib/dpkg/lock

    推荐博客:http://blog.sina.com.cn/s/blog_5c1450a8010188ju.html Ubuntu 使用apt-get时提示错误:无法获得锁 /var/lib/dpkg/ ...

  6. NopCommerce架构分析(转载)

    原文 一,NopCommerce架构分析之开篇 NopCommerce是.net开源项目中比较成熟的一款业务应用框架,也是电子商务系统中的典范.所以很想多学习一下里面的设计和实现方式. 二,NopCo ...

  7. HTML页面规范

    <!DOCTYPE HTML> <html> <head> <meta charset="UTF-8"> <title> ...

  8. Bzoj 4408: [Fjoi 2016]神秘数 可持久化线段树,神题

    4408: [Fjoi 2016]神秘数 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 177  Solved: 128[Submit][Status ...

  9. 2 weekend110的zookeeper的原理、特性、数据模型、节点、角色、顺序号、读写机制、保证、API接口、ACL、选举、 + 应用场景:统一命名服务、配置管理、集群管理、共享锁、队列管理

    在hadoop生态圈里,很多地方都需zookeeper. 启动的时候,都是普通的server,但在启动过程中,通过一个特定的选举机制,选出一个leader. 只运行在一台服务器上,适合测试环境:Zoo ...

  10. poj 2186 Popular Cows【tarjan求scc个数&&缩点】【求一个图中可以到达其余所有任意点的点的个数】

    Popular Cows Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 27698   Accepted: 11148 De ...