模拟连接池

Posted 【我是谁】

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了模拟连接池相关的知识,希望对你有一定的参考价值。

实例代码:主要是lock防止池在同一时间被其它线程占用

  //假设这个类型的对象创建起来比较耗时
    public class TimeConsumeConnection
    {
    }
 internal class Program
    {
        private static readonly object Sync = new object();

        private static void Main(string[] args)
        {
            //假设一个池
            TimeConsumeConnection[] conPool = new TimeConsumeConnection[100];
            //声明一个变量来维护当前池中的对象的个数。
            int count = 0;

            //生产者,假设5个线程同时在进行“生产”→创建对象并加入到conPool池中
            for (int i = 0; i < 5; i++)
            {
                //没循环一次创建一个线程
                Thread t = new Thread(() =>
                {
                    //不断的生产对象并加入到conPool池中
                    while (true)
                    {
                        lock (Sync)
                        {
                            if (count < conPool.Length)
                            {
                                //创建一个Connection对象并把该对象加到conPool池中
                                TimeConsumeConnection connection = new TimeConsumeConnection();
                                conPool[count] = connection;
                                count++;
                                Console.WriteLine("生产了一个对象。");
                            }
                        }
                        Thread.Sleep(300);
                    }
                })
                { IsBackground = true };
                t.Start();
            }

            //消费者假设有10个消费者,从池中获取对象并使用
            for (int i = 0; i < 10; i++)
            {
                Thread t = new Thread(() =>
                {
                    while (true)
                    {
                        lock (Sync)
                        {
                            //在消费对象前,要判断一下池中是否有可用对象
                            if (count > 0)
                            {
                                TimeConsumeConnection con = conPool[count - 1];
                                Console.WriteLine("使用该对象:" + con);
                                conPool[count - 1] = null;
                                count--;
                            }
                        }
                        Thread.Sleep(50);
                    }
                })
                { IsBackground = true };
                t.Start();
            }
            Console.ReadKey();
        }
    }

  

以上是关于模拟连接池的主要内容,如果未能解决你的问题,请参考以下文章

数据库连接池原理分析及模拟实现

Druid连接池&Template组件&三级分层开发,模拟账号登陆

jedis连接redis

newCacheThreadPool()newFixedThreadPool()newScheduledThreadPool()newSingleThreadExecutor()自定义线程池(代码片段

连接池报错 Proxool Provider unable to load JAXP configurator file: proxool.xml

稳定性 耗时 监控原因分析-- dubbo rpc 框架 的线程池,io 连接模型. 客户端,服务端