我正在使用Hibernate 4.2和构建时字节码检测来解决出现在@OneToOne
关系和@Lob
(https://developer.jboss.org/wiki/SomeExplanationsOnLazyLoadingone-to-one)上的懒惰问题
你知道两者之间的区别是什么吗:
Hibernate字节码插桩:http://docs.jboss.org/hibernate/orm/4.3/manual/en-US/html/ch20.html#performance-fetching-lazyproperties
Hibernate字节码增强:http://docs.jboss.org/hibernate/orm/4.3/manual/en-US/html/ch20.html#bytecode-enhancement
因为在hibernate留档上,写着:
增强任务旨在完全替代InstrumentTask。此外,它也与InstrumentTask不兼容,因此任何现有的检测类都需要再次从源代码构建。
我可以通过使用字节码插桩来解决我的问题,但使用字节码增强不起作用。你知道为什么吗?
也许,这个新功能还没有完全开发?
谢谢你的帮助。
答案是字节码增强的方式。让我们看看这两种情况下会发生什么
和
字节码增强:字节码增强可以在运行时执行,也可以在构建时(离线)执行。当在运行时执行增强时,持久性类会在加载时得到增强。当离线执行增强时,类文件会在编译后步骤中得到增强;
在大多数字节码增强的情况下,它们是在编译后完成的。如果您的Hibernate字节码增强是这种情况,那么是的,更改代码的明显选择是字节码插桩。