Hibernate implementation. Are we paying the reflection penalty?

后端 未结 5 1971
栀梦
栀梦 2021-01-06 01:51

Long time ago, I was creating a mini ORM using reflection.

While reading about reflection I got a similar answer like this:

Java Reflection Performance

5条回答
  •  时光说笑
    2021-01-06 02:06

    Hibernate instruments your models to be hibernate aware.

    There are varying levels of cost for using Reflection. Constantly looking up a method for a particular class is particularly expensive. Executing a method via reflection using a cached copy is not that much slower. If one thinks of the tasks that the reflection api must complete to invoke the method it all makes sense which each part is slow and consumes cpu cycles.

    Locating a method

    • Visit each and every method of a particular class
    • Test each methods visibility, method signature etc.
    • Generate bytecode for found method.

    One factors in the numbers of methods in a typical class and that some of these operations arent trivial it becomes obvious that this can be costly.

    Invoking the method.

    Each reflected method amounts to a bit of byte code that invokes the target method with a bit of boilerplate to match the reflection interface. Before it can do that it must perform some sanity checks so it can complain with nice messages rather than letting the runtime throw ClassCastException and similar exceptions.

    • If an instance method check the instance passed in isnt null and is the right type.
    • Check the arguments parameter includes the right amount and type of parameters.
    • Execute the method within a try catch. In the catch throw ITE etc.

    All these extras add some cost - not a lot but it does make things slower.

    Runtime costs

    In general caching methods and invoking that isnt cost but is a bit slower. The reflection api itself does attempt to cache methods and classes but finding the right method and so on is still a slow operation.

提交回复
热议问题