- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我使用 Byte-Buddy 动态生成 Java 接口(interface)方法的实现,并将对这些方法的调用委托(delegate)给现有代理对象的单个方法。
第一个版本的灵感来自How to create a dynamic proxy using ByteBuddy
它使用反射InitationHandler
即具体代理类:
InitationHandler
invoke()
这很好用。
然后重新阅读Byte-Buddy readme on Github我发现了一个使用“GeneralInterceptor”的 MethodDelegation
的替代版本。
即具体代理类:
RuntimeType
注释标记的方法。这也很好用!
下面的代码片段演示了这两种技术。
Class<? extends Object> clazz = new ByteBuddy()
.subclass(serviceSuperClass)
.name(className)
// use a Reflection InvocationHander for the methods of serviceInterfaceOne
.implement(serviceInterfaceOne)
.defineField(invocationHandler, MyProxy.class, Visibility.PUBLIC)
.method(isDeclaredBy(serviceInterfaceOne))
.intercept(InvocationHandlerAdapter.toField(invocationHandler))
// use a Byte-Buddy "GeneralInterceptor" for the methods of serviceInterfaceTwo
.implement(serviceInterfaceTwo)
.defineField(generalInterceptor, MyProxy.class, Visibility.PUBLIC)
.method(isDeclaredBy(serviceInterfaceTwo))
.intercept(MethodDelegation.toField(generalInterceptor))
//
.make ()
.load(classLoader)
.getLoaded();
public class MyProxy implements InvocationHandler {
@Override
public Object invoke(Object serviceImpl, Method method, Object[] args) throws Throwable {
return null;
}
@RuntimeType
public Object intercept(@AllArguments Object[] allArguments,
@Origin Method method) {
return null;
}
}
从高层次的角度来看,这两种技术都允许我做同样的事情:
即拦截给定的动态创建的方法到现有的具体方法。
两种解决方案都很优雅,并且所需的代码量相似。
问题是:有什么理由更喜欢其中一个而不是另一个?例如表现?功能?
最佳答案
在这种使用形式中,除了委托(delegate)可以连接到任何(静态或非静态)方法而调用处理程序适配器仅桥接 Java 代理 API 的实现之外,没有真正的区别。这主要意味着如果您已经实现了此类代理处理程序并希望通过 Byte Buddy 重用它们。
Byte Buddy 的处理程序比处理程序 API 具有更大的灵 active ,从而提高了性能,因为如果您知道需要什么参数,您就可以避免数组装箱。它还允许不同的机制,例如调用调用处理程序 API 不支持的默认方法实现。
关于java - Byte-Buddy:方法拦截 InvoiceHandler 与 MethodDelegation 到 GeneralInterceptor,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60317919/
我使用 Byte-Buddy 动态生成 Java 接口(interface)方法的实现,并将对这些方法的调用委托(delegate)给现有代理对象的单个方法。 第一个版本的灵感来自How to cre
我是一名优秀的程序员,十分优秀!