为什么现在各种池子越来越频繁使用呢,我认为本质的原因就是增加效率,怎么增加效率呢?
一般来说,一个东西比如说线程或者内存,为什么要构建线程池或者内存池呢。因为在一个项目中如果需要频繁的创建和关闭线程或者频繁的申请和释放内存,这种操作是很耗时的。为了避免这种资源和性能的消耗所以采用池子的方式,这样可以快速的复用,提高程序的性能。
再比如说数据库连接池,以mysql连接池为例,一般是TCP链接后面跟着mysql的协议,TCP的链接我们知道连接时要经过三次握手,关闭时也需要四次挥手。同样mysql协议的连接认证和关闭也需要一个过程,如果频繁的触发肯定会对系统的性能有影响的。因此就需要连接池了。
这里引用两张前辈的图片增加理解:
题外话:我们cpu当中的缓存跟这个道理很相似,都是为了快速的访问,增加性能。cpu的速度和内存读取的速度的巨大差别,造就了缓存这个概念。