对象池服务可以减少从头创建每个对象的系统开销。在激活对象时,它从池中提取。在停用对象时,它放回池中,等待下一个请求。
我们来看下主线程中,如何与对象池打交道:

  1. static void Main(string[] args)
  2. {
  3. InstancePoolResolver.Register<OrderQueryServiceInterface, OrderQueryService>();
  4.  
  5. while (true)
  6. {
  7. Thread.Sleep();
  8. Console.Clear();
  9.  
  10. for (int i = ; i < ;i++ )
  11. {
  12. ThreadPool.QueueUserWorkItem(new WaitCallback(ConsumeObject));
  13. }
  14. }
  15. }
  16.  
  17. private static void ConsumeObject(object state)
  18. {
  19. OrderQueryServiceInterface srv = null;
  20. try
  21. {
  22. using (srv = InstancePoolResolver.Resolve<OrderQueryServiceInterface>()) //从对象池中取得对象,没有可用对象则throw exception
  23. {
  24. Console.WriteLine("Object ID--->" + srv.GetHashCode());
  25. Thread.Sleep(); //故意长时间占用对象
  26. }
  27. }
  28. catch (Exception ex)
  29. {
  30. Console.WriteLine(ex.Message);
  31. }
  32. finally
  33. {
  34. if (srv != null)
  35. srv.Dispose();
  36. }
  37. }

运行效果:

最多只有2个instance,那在哪里设置这个数量呢?请看

是通过Attribute打tag上去的

下面来看看最核心的InstancePoolResolver类

  1. public sealed class InstancePoolResolver
  2. {
  3. private static Dictionary<Type, Type> typeMappers = new Dictionary<Type, Type>();
  4. private static Dictionary<Type, int> typeMappersMaxInstanceCount = new Dictionary<Type, int>();
  5. private static Dictionary<Type, List<PoolableObject>> typeInstances = new Dictionary<Type, List<PoolableObject>>();
  6.  
  7. private static object o4lock = new object();
  8. public static void Register<T, TProvider>()
  9. where TProvider : class, new()
  10. {
  11. if (typeMappers.ContainsKey(typeof(T)))
  12. throw new Exception("Key existed");
  13.  
  14. lock (o4lock)
  15. {
  16. Type t = typeof(T);
  17. typeMappers.Add(t, typeof(TProvider));
  18. typeInstances.Add(t, new List<PoolableObject>());
  19.  
  20. InstanceSettingAttribute setting = GetInstanceSettingAttribute(typeof(TProvider));
  21. typeMappersMaxInstanceCount.Add(t, setting.MaxInstanceGlobal);
  22. }
  23. }
  24.  
  25. public static T Resolve<T>()
  26. where T: PoolableObject
  27. {
  28. Type t = typeof(T);
  29. if (!typeMappers.ContainsKey(t) || !typeInstances.ContainsKey(t))
  30. throw new Exception("Key empty, register please");
  31.  
  32. lock (o4lock)
  33. {
  34. List<PoolableObject> instances = typeInstances[t];
  35. if (instances == null)
  36. {
  37. instances = new List<PoolableObject>();
  38. typeInstances[t] = instances;
  39. }
  40. foreach (PoolableObject o in instances)//是否已经存在已有闲置对象
  41. {
  42. if (o.IsInPool)
  43. {
  44. o.IsInPool = false;
  45. return (T)o;
  46. }
  47. }
  48. if (instances.Count < typeMappersMaxInstanceCount[t])//new新对象到对象池中
  49. {
  50. Type type = typeMappers[t];
  51. PoolableObject obj = (PoolableObject)Activator.CreateInstance(type);
  52. instances.Add(obj);
  53. obj.IsInPool = false;
  54. return (T)obj;
  55. }
  56. }
  57. throw new Exception("Object Pool fulled!"); //没有多余的资源
  58. }
  59.  
  60. private static InstanceSettingAttribute GetInstanceSettingAttribute(Type type)
  61. {
  62. object[] attrs = type.GetCustomAttributes(typeof(InstanceSettingAttribute), false);
  63. if (attrs == null || attrs.Count() == )
  64. return new InstanceSettingAttribute() { MaxInstanceGlobal=};
  65.  
  66. return (InstanceSettingAttribute)attrs[];
  67. }
  68. }

其实很简单,只是多了个获取Attribute的函数

C# 对象池的实现(能限制最大实例数量,类似于WCF的MaxInstanceCount功能)的更多相关文章

  1. 深度剖析C++对象池自动回收技术实现

    http://www.tuicool.com/articles/mQBfQfN 对象池可以显著提高性能,如果一个对象的创建非常耗时或非常昂贵,频繁去创建的话会非常低效.对象池通过对象复用的方式来避免重 ...

  2. Apache common pool2 对象池

    对象池的容器:包含一个指定数量的对象.从池中取出一个对象时,它就不存在池中,直到它被放回.在池中的对象有生命周期:创建,验证,销毁,对象池有助于更好地管理可用资源,防止JVM内部大量临时小对象,频繁触 ...

  3. Java之对象池

    单例模式是限制了一个类只能有一个实例,对象池模式则是限制一个类实例的个数.对象池类就像是一个对象管理员,它以Static列表(也就是装对象的池子)的形式存存储某个实例数受限的类的实例,每一个实例还要加 ...

  4. Java对象池

    单例模式是限制了一个类只能有一个实例,对象池模式则是限制一个类实例的个数.对象池类就像是一个对象管理员,它以Static列表(也就是装对象的池子)的形式存存储某个实例数受限的类的实例,每一个实例还要加 ...

  5. Java对象池示例

    单例模式是限制了一个类只能有一个实例,对象池模式则是限制一个类实例的个数.对象池类就像是一个对象管理员,它以Static列表(也就是装对象的池子)的形式存存储某个实例数受限的类的实例,每一个实例还要加 ...

  6. 对象池在 .NET (Core)中的应用[1]: 编程体验

    借助于有效的自动化垃圾回收机制,.NET让开发人员不在关心对象的生命周期,但实际上很多性能问题都来源于GC.并不说.NET的GC有什么问题,而是对象生命周期的跟踪和管理本身是需要成本的,不论交给应用还 ...

  7. 对象池在 .NET (Core)中的应用[2]: 设计篇

    <编程篇>已经涉及到了对象池模型的大部分核心接口和类型.对象池模型其实是很简单的,不过其中有一些为了提升性能而刻意为之的实现细节倒是值得我们关注.总的来说,对象池模型由三个核心对象构成,它 ...

  8. 设计模式之美:Object Pool(对象池)

    索引 意图 结构 参与者 适用性 效果 相关模式 实现 实现方式(一):实现 DatabaseConnectionPool 类. 实现方式(二):使用对象构造方法和预分配方式实现 ObjectPool ...

  9. Egret中的对象池ObjectPool

    为了可以让对象复用,防止大量重复创建对象,导致资源浪费,使用对象池来管理. 对象池具体含义作用,自行百度. 一 对象池A 二 对象池B 三 字符串key和对象key的效率 一 对象池A /** * 对 ...

随机推荐

  1. (办公)rom包

    所谓ROM包,通俗点来讲,也就是手机上的系统安装包.使用过智能手机的朋友可能都有过这样的遗憾,自己所用的官方系统虽然能够满足绝大部分的需求,但总有一些细节不是很合自己的心愿……比如说,内置的输入法不好 ...

  2. Python笔记(十七):生成器

    (一)生成器(Generator) Python生成器是创建迭代器的简单方法.简单来说,生成器是一个函数,它返回一个我们可以迭代的对象(迭代器)(一次一个值). 因为下面会用到列表生成式,这里先说明下 ...

  3. Spark WordCount 文档词频计数

    一.使用数据 Apache Spark is a fast and general-purpose cluster computing system.It provides high-level AP ...

  4. Azure SQL Virtual Machine报Login failed for user 'NT Service\SqlIaaSExtension'. Reason: Could not find a login matching the name provided

    在一台位于HK的Azure SQL Virtual Machine上修改排序规则,重建系统数据库后,监控发现大量的登录失败告警生成,如下所示: DESCRIPTION:  Login failed f ...

  5. 设计模式java----单例模式

    一.懒汉式单例 在第一次调用的时候实例化自己,Singleton的唯一实例只能通过getInstance()方法访问.线程不安全 /** * Created by Admin on 2017/3/19 ...

  6. SQL SERVER 查询表的行数

    SELECT OBJECT_NAME(ii.id) TableName ,rows FROM sysindexes ii INNER JOIN sysobjects oo ON ( oo.id = i ...

  7. Linux进程上下文切换过程context_switch详解--Linux进程的管理与调度(二十一)

    1 前景回顾 1.1 Linux的调度器组成 2个调度器 可以用两种方法来激活调度 一种是直接的, 比如进程打算睡眠或出于其他原因放弃CPU 另一种是通过周期性的机制, 以固定的频率运行, 不时的检测 ...

  8. Cs231n课堂内容记录-Lecture2-Part2 线性分类

    Lecture 3 课程内容记录:(上)https://zhuanlan.zhihu.com/p/20918580?refer=intelligentunit (中)https://zhuanlan. ...

  9. Thinkphp框架中自定义修改success和error页面

    Thinkphp框架中自定义修改success和error页面 Thinkphp框架的默认success和error太难看,可以自定义设置,步骤如下: (注意:TP原框架中的success跳转有问题, ...

  10. LeetCode算法题-Invert Binary Tree

    这是悦乐书的第194次更新,第199篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第55题(顺位题号是226).反转二叉树.例如: 输入: 4 / \ 2 7 / \ / ...