2021SC@SDUSC
这一次的博客是对上一次博客的继续,首先是对spring文件夹里的avalon文件夹的剩余代码进行分析,然后继续分析core文件夹下的其他文件夹的内容。包括spring文件夹下的logger,以及xml文件夹下的avalon,和core文件夹下的一些其他java文件,由于内容很多,我可能会选择重点分析,有一些不太重点的类就一笔带过吧。
PoolableFactoryBean.java
这个factory bean向Spring添加了简单的池支持。
一些需要关注的属性:
属性名称 | 属性说明 |
---|---|
beanClass | 类 |
beanFactory | 相应的bean factory |
DEFAULT_MAX_POOL_SIZE | 池的默认最大大小 |
interfaces | 代理的所有接口 |
name | 混合组件 |
semaphore | 对象,用于同步对get和put方法的访问 |
构造函数:
重载,创建一个PoolableComponentHandler来管理由指定工厂对象创建的组件池。
public PoolableFactoryBean( String name, String className )
throws Exception {
this(name, className, DEFAULT_MAX_POOL_SIZE, null);
}
public PoolableFactoryBean( String name, String className, String poolMaxString, Settings settings )
throws Exception {
String value = poolMaxString;
if ( settings != null ) {
value = PropertyHelper.replace(poolMaxString, settings);
}
int poolMax = Integer.valueOf(value).intValue();
this.name = name;
this.max = ( poolMax <= 0 ? Integer.MAX_VALUE : poolMax );
this.beanClass = Class.forName(className);
final HashSet workInterfaces = new HashSet();
//得到所有接口
this.guessWorkInterfaces( this.beanClass, workInterfaces );
//增加 AvalonPoolable
workInterfaces.add(AvalonPoolable.class);
this.interfaces = (Class[]) workInterfaces.toArray( new Class[workInterfaces.size()] );
//创建池列表
this.ready = new LinkedList();
}
其他重要的方法:
1.dispose()
:
处理关联的池和工厂。
public void dispose() {
//准备列表中的任何Poolables都需要处理
synchronized( this.semaphore ) {
//移除准备列表中的对象
for( Iterator iter = this.ready.iterator(); iter.hasNext(); ) {
Object poolable = iter.next();
iter.remove();
this.readySize--;
this.permanentlyRemovePoolable( poolable );
}
}
}
2.enteringPool()
:
处理特定于服务的方法,将其放入池中
protected void enteringPool( final Object component ) {
try {
//处理可回收的对象