iBATIS的Log机制浅谈
创始人
2024-04-16 11:21:03
0

iBATIS的Log机制的问题我们要首先从iBATIS的Log使用的两个类开始,他们是:
 
com.ibatis.common.logging.LogFactory

com.ibatis.common.logging.Log

查看这两个类的源代码,可以发现它不过是对org.apache.commons.logging、org.apache.log4j、java.util.logging,三种目前可用的Log框架的同时封装。

开始时很费解,不知iBATIS开发者为何要采用这种方式,直接使用某个确定的Log不就可以了吗?思考后发现原因如下:

“iBATIS宣称自己具有最少的第三方依赖性,其Log采用以上机制的原因也正在于此:如果iBATIS采用某个特定的Log框架,那么它就必须添加对该框架的依赖关系;而考虑到使用iBATIS的开发者肯定会使用以上三个Log框架中的某个,因此iBATIS决定与其使用者共用该框架;这样iBATIS就可以避免不必要的第三方依赖;另外,如果开发者的确没有使用某Log框架,查看iBATIS的Log代码可以发现它对此也有相应措施,即不log出任何东西。”

思考明白以上原因后,再查看com.ibatis.common.logging.LogFactory的代码,就不难理解了,但还是说明几个小点:

  1. private static void tryImplementation(String testClassName, String implClassName) ...{  
  2.  
  3.     if (logConstructor == null) ...{  
  4.  
  5.       try ...{  
  6.  
  7.         Resources.classForName(testClassName);  
  8.  
  9.         Class implClass = Resources.classForName(implClassName);  
  10.  
  11.         logConstructor = implClass.getConstructor(new Class[]...{Class.class});  
  12.  
  13.       } catch (Throwable t) ...{  
  14.  
  15.       }  
  16.  
  17.     }  
  18.  
  19.  } 

testClassName为某Log框架中的工厂类的类名,implClassName为该框架相应Log接口实现类的类名(该类属于iBATIS)。代码先加载工厂类,然后加载实现类,得到其class,并由class得到constructor,供getLog方法调用时使用。

iBATIS的Log机制就向你介绍到这里,希望对于你理解iBATIS的Log机制有所帮助。

【编辑推荐】

  1. iBATIS事务处理浅析
  2. iBatis和Hibernate的较量浅析
  3. iBATIS动态映射浅析
  4. iBATIS DAO框架浅析
  5. iBATIS的自动代码生成工具Abator在Eclipse的应用

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...