当前位置: 移动技术网 > IT编程>开发语言>Java > Hibernate包作用详解

Hibernate包作用详解

2017年12月12日  | 移动技术网IT编程  | 我要评论

kproxy,例外被抛出且未被接住,最强的系统

hibernate一共包括了23个jar包,令人眼花缭乱。本文将详细讲解hibernate每个jar包的作用,便于你在应用中根据自己的需要进行取舍。

  下载hibernate,例如2.0.3稳定版本,解压缩,可以看到一个hibernate2.jar和lib目录下有22个jar包:

  hibernate2.jar:
  hibernate的库,没有什么可说的,必须使用的jar包

  cglib-asm.jar:
  cglib库,hibernate用它来实现po字节码的动态生成,非常核心的库,必须使用的jar包

  dom4j.jar:
  dom4j是一个java的xml api,类似于jdom,用来读写xml文件的。dom4j是一个非常非常优秀的java xml api,具有性能优异、功能强大和极端易用使用的特点,同时它也是一个开放源代码的软件,可以在sourceforge上找到它。在ibm developerworks上面可以找到一篇文章,对主流的java xml api进行的性能、功能和易用性的评测,dom4j无论在那个方面都是非常出色的。我早在将近两年之前就开始使用dom4j,直到现在。如今你可以看到越来越多的java软件都在使用dom4j来读写xml,特别值得一提的是连sun的jaxm也在用dom4j。这是必须使用的jar包,hibernate用它来读写配置文件。

  odmg.jar:
  odmg是一个orm的规范,hibernate实现了odmg规范,这是一个核心的库,必须使用的jar包。

  commons-collections.jar:
  apache commons包中的一个,包含了一些apache开发的集合类,功能比java.util.*强大。必须使用的jar包。

  commons-beanutils.jar:
  apache commons包中的一个,包含了一些bean工具类类。必须使用的jar包。

  commons-lang.jar:
  apache commons包中的一个,包含了一些数据类型工具类,是java.lang.*的扩展。必须使用的jar包。

  commons-logging.jar:
  apache commons包中的一个,包含了日志功能,必须使用的jar包。这个包本身包含了一个simple logger,但是功能很弱。在运行的时候它会先在classpath找log4j,如果有,就使用log4j,如果没有,就找jdk1.4带的java.util.logging,如果也找不到就用simple logger。commons-logging.jar的出现是一个历史的的遗留的遗憾,当初apache极力游说sun把log4j加入jdk1.4,然而jdk1.4项目小组已经接近发布jdk1.4产品的时间了,因此拒绝了apache的要求,使用自己的java.util.logging,这个包的功能比log4j差的很远,性能也一般。

  后来apache就开发出来了commons-logging.jar用来兼容两个logger。因此用commons-logging.jar写的log程序,底层的logger是可以切换的,你可以选择log4j,java.util.logging或者它自带的simple logger。不过我仍然强烈建议使用log4j,因为log4j性能很高,log输出信息时间几乎等于system.out,而处理一条log平均只需要5us。你可以在hibernate的src目录下找到hibernate已经为你准备好了的log4j的配置文件,你只需要到apache 网站去下载log4j就可以了。commons-logging.jar也是必须的jar包。

  使用hibernate必须的jar包就是以上的这几个,剩下的都是可选的。

  ant.jar:
  ant编译工具的jar包,用来编译hibernate源代码的。如果你不准备修改和编译hibernate源代码,那么就没有什么用,可选的jar包

  optional.jar:
  ant的一个辅助包。

  c3p0.jar:
  c3po是一个数据库连接池,hibernate可以配置为使用c3po连接池。如果你准备用这个连接池,就需要这个jar包。

  proxool.jar:
  也是一个连接池,同上。

  commons-pool.jar, commons-dbcp.jar:
  dbcp数据库连接池,apache的jakarta组织开发的,tomcat4的连接池也是dbcp。

  实际上hibernate自己也实现了一个非常非常简单的数据库连接池,加上上面3个,你实际上可以在hibernate上选择4种不同的数据库连接池,选择哪一个看个人的偏好,不过dbcp可能更通用一些。另外强调一点,如果在ejb中使用hibernate,一定要用app server的连接池,不要用以上4种连接池,否则容器管理事务不起作用。

  connector.jar:
  jca 规范,如果你在app server上把hibernate配置为connector的话,就需要这个jar。不过实际上一般app server肯定会带上这个包,所以实际上是多余的包。

  jaas.jar:
  jaas是用来进行权限验证的,已经包含在jdk1.4里面了。所以实际上是多余的包。

  jcs.jar:
  如果你准备在hibernate中使用jcs的话,那么必须包括它,否则就不用。

  jdbc2_0-stdext.jar:
  jdbc2.0的扩展包,一般来说数据库连接池会用上它。不过app server都会带上,所以也是多余的。

  jta.jar:
  jta规范,当hibernate使用jta的时候需要,不过app server都会带上,所以也是多余的。

  junit.jar:
  junit包,当你运行hibernate自带的测试代码的时候需要,否则就不用。

  xalan.jar, xerces.jar, xml-apis.jar:
  xerces是xml解析器,xalan是格式化器,xml-apis实际上是jaxp。一般app server都会带上,jdk1.4也包含了解析器,不过不是xerces,是crimson,效率比较差,不过hibernate用xml只不过是读取配置文件,性能没什么紧要的,所以也是多余的。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网