Back to project page objenesis.
The source code is released under:
Apache License
If you think the Android project objenesis listed in this page is inappropriate, such as containing malicious code/tools or violating the copyright, please email info at java2s dot com, thanks.
/** * Copyright 2006-2015 the original author or authors. *//ww w. j av a2 s. c o m * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.objenesis.strategy; import static org.objenesis.strategy.PlatformDescription.*; import org.objenesis.instantiator.ObjectInstantiator; import org.objenesis.instantiator.android.Android10Instantiator; import org.objenesis.instantiator.android.Android17Instantiator; import org.objenesis.instantiator.android.Android18Instantiator; import org.objenesis.instantiator.gcj.GCJInstantiator; import org.objenesis.instantiator.jrockit.JRockitLegacyInstantiator; import org.objenesis.instantiator.perc.PercInstantiator; import org.objenesis.instantiator.sun.SunReflectionFactoryInstantiator; import org.objenesis.instantiator.sun.UnsafeFactoryInstantiator; /** * Guess the best instantiator for a given class. The instantiator will instantiate the class * without calling any constructor. Currently, the selection doesn't depend on the class. It relies * on the * <ul> * <li>JVM version</li> * <li>JVM vendor</li> * <li>JVM vendor version</li> * </ul> * However, instantiators are stateful and so dedicated to their class. * * @author Henri Tremblay * @see ObjectInstantiator */ public class StdInstantiatorStrategy extends BaseInstantiatorStrategy { /** * Return an {@link ObjectInstantiator} allowing to create instance without any constructor being * called. * * @param type Class to instantiate * @return The ObjectInstantiator for the class */ public <T> ObjectInstantiator<T> newInstantiatorOf(Class<T> type) { if(PlatformDescription.isThisJVM(SUN) || PlatformDescription.isThisJVM(OPENJDK)) { // The UnsafeFactoryInstantiator would also work. But according to benchmarks, it is 2.5 // times slower. So I prefer to use this one return new SunReflectionFactoryInstantiator<T>(type); } else if(PlatformDescription.isThisJVM(JROCKIT)) { if(VM_VERSION.startsWith("1.4")) { // JRockit vendor version will be RXX where XX is the version // Versions prior to 26 need special handling // From R26 on, java.vm.version starts with R if(!VENDOR_VERSION.startsWith("R")) { // On R25.1 and R25.2, ReflectionFactory should work. Otherwise, we must use the // Legacy instantiator. if(VM_INFO == null || !VM_INFO.startsWith("R25.1") || !VM_INFO.startsWith("R25.2")) { return new JRockitLegacyInstantiator<T>(type); } } } // After that, JRockit became compliant with HotSpot return new SunReflectionFactoryInstantiator<T>(type); } else if(PlatformDescription.isThisJVM(DALVIK)) { if(ANDROID_VERSION <= 10) { // Android 2.3 Gingerbread and lower return new Android10Instantiator<T>(type); } if(ANDROID_VERSION <= 17) { // Android 3.0 Honeycomb to 4.2 Jelly Bean return new Android17Instantiator<T>(type); } // Android 4.3 and higher (hopefully) return new Android18Instantiator<T>(type); } else if(PlatformDescription.isThisJVM(GNU)) { return new GCJInstantiator<T>(type); } else if(PlatformDescription.isThisJVM(PERC)) { return new PercInstantiator<T>(type); } // Fallback instantiator, should work with most modern JVM return new UnsafeFactoryInstantiator<T>(type); } }