Access the Constructor of the Channel in the constructor of ReflectiveChannelFactory. (#8718)
Motivation: We should access the Constructor of the passed in class in the Constructor of ReflectiveChannelFactory only to reduce the overhead but also fail-fast. Modifications: Access the Constructor early. Result: Fails fast and less performance overhead.
This commit is contained in:
parent
f08e80ffd6
commit
ddc9f8bf1d
@ -16,33 +16,40 @@
|
||||
|
||||
package io.netty.channel;
|
||||
|
||||
import io.netty.util.internal.ObjectUtil;
|
||||
import io.netty.util.internal.StringUtil;
|
||||
|
||||
import java.lang.reflect.Constructor;
|
||||
|
||||
/**
|
||||
* A {@link ChannelFactory} that instantiates a new {@link Channel} by invoking its default constructor reflectively.
|
||||
*/
|
||||
public class ReflectiveChannelFactory<T extends Channel> implements ChannelFactory<T> {
|
||||
|
||||
private final Class<? extends T> clazz;
|
||||
private final Constructor<? extends T> constructor;
|
||||
|
||||
public ReflectiveChannelFactory(Class<? extends T> clazz) {
|
||||
if (clazz == null) {
|
||||
throw new NullPointerException("clazz");
|
||||
ObjectUtil.checkNotNull(clazz, "clazz");
|
||||
try {
|
||||
this.constructor = clazz.getConstructor(EventLoop.class);
|
||||
} catch (NoSuchMethodException e) {
|
||||
throw new IllegalArgumentException("Class " + StringUtil.simpleClassName(clazz) +
|
||||
" does not have a public constructor that takes an EventLoop instance", e);
|
||||
}
|
||||
this.clazz = clazz;
|
||||
}
|
||||
|
||||
@Override
|
||||
public T newChannel(EventLoop eventLoop) throws Exception {
|
||||
try {
|
||||
return clazz.getConstructor(EventLoop.class).newInstance(eventLoop);
|
||||
return constructor.newInstance(eventLoop);
|
||||
} catch (Throwable t) {
|
||||
throw new ChannelException("Unable to create Channel from class " + clazz, t);
|
||||
throw new ChannelException("Unable to create Channel from class " + constructor.getDeclaringClass(), t);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return StringUtil.simpleClassName(clazz) + ".class";
|
||||
return StringUtil.simpleClassName(ReflectiveChannelFactory.class) +
|
||||
'(' + StringUtil.simpleClassName(constructor.getDeclaringClass()) + ".class)";
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user