关于各种池子的理解(连接池,线程池,内存池)

为什么现在各种池子越来越频繁使用呢,我认为本质的原因就是增加效率,怎么增加效率呢?

一般来说,一个东西比如说线程或者内存,为什么要构建线程池或者内存池呢。因为在一个项目中如果需要频繁的创建和关闭线程或者频繁的申请和释放内存,这种操作是很耗时的。为了避免这种资源和性能的消耗所以采用池子的方式,这样可以快速的复用,提高程序的性能。

再比如说数据库连接池,以mysql连接池为例,一般是TCP链接后面跟着mysql的协议,TCP的链接我们知道连接时要经过三次握手,关闭时也需要四次挥手。同样mysql协议的连接认证和关闭也需要一个过程,如果频繁的触发肯定会对系统的性能有影响的。因此就需要连接池了。

这里引用两张前辈的图片增加理解:

 

 

题外话:我们cpu当中的缓存跟这个道理很相似,都是为了快速的访问,增加性能。cpu的速度和内存读取的速度的巨大差别,造就了缓存这个概念。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

编程经验随笔

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值