原文地址:http://otl.sourceforge.net/otl3_stream_pooling.htm
OTL缓冲池是这样一种机制,它使那些没有进行有效管理的otl_stream变得足够高效.otl_stream实例变量存放在缓冲池中,即使实例被关闭,在程序中我们依然可以对它进行复用.典型的情况就是,程序会在函数中定义一些otl_stream类型的局部变量.特别是当这些函数被重复调用时,这些otl_stream实例就会一再的被实例化和关闭.
每个流在实例化时都会在数据库后端触发解析流中的SQL指令,这是一个相对昂贵的操作.OTL缓冲流机制减轻这种负担并简化了编码技术.
关闭一个流实例,实际上就是把这个实例保存在缓冲池中.这时,当有一个相似OTL流的请求时,这个实例就会被赋值给这个otl_stream变量.这个变量可能是在堆中的分配的变量,也可能是函数中的局部变量(即在栈中分配的变量--译注)。具有相同的缓冲区大小和SQL指令文本的流被视为相似的,也就是说具有相同SQL指令和缓冲区大小的流会被保存在缓冲池的同一个桶中.
这么说,有三个<buf_size1+SQLStm1>相似流的实例分配,然后关闭了,缓冲池将这三个流实例保存在同一个桶中(如下图所示)并只提供一个入口访问点.之后,