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:
Norman Maurer 2019-01-15 08:38:13 +01:00
parent f08e80ffd6
commit ddc9f8bf1d

View File

@ -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)";
}
}