谨慎使用类变量及正确使用单例模式

来源:互联网 发布:charles中文破解版mac 编辑:程序博客网 时间:2024/05/22 21:23

昨天发现JDBMonitor在多数据源的情况下会有问题,这个问题就是对单例模式理解不深造成的。为了减少系统中的对象数目,我用单例模式设计 DBLogger,也就是提供一个getLogger方法返回一个日志处理器,getLogger则返回的是一个缓存了的DBLogger实例。昨天我用一个大型的信息系统测试了一下,发现当有多个数据源存在的时候,所有的日志都记录到了第一个启动的JDBMonitor的配置文件指定的监听器中了。经过分析得知,虽然多个数据源启动了多个JDBMonitor,但是由于这些JDBMonitor实例是运行在同一个JVM中的,而一个类变量在同一个JVM 是唯一的,所以这些实例调用getLogger的时候得到的都是第一个JDBMonitor中配置的了。

全文阅读:http://www.javah.net/JAVAmoshi/20070516/1402.html

原创粉丝点击