- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我刚开始玩 ByteBuddy,我正在研究几个示例以掌握它的窍门。
我想通过这个练习完成的是用 ByteBuddy 替换一些使用 ASM 的代码。
到目前为止,我在非泛型方面取得了成功。例如,我可以很容易地定义一个字段,例如这样
builder.defineField("names", List.class, Visibility.PRIVATE)
如果我只想创建一个原始字段 List
类型。
然而,当谈到引入泛型时,我被卡住了。
显然,我定义字段的方式(使用 Class
)意味着通用类型丢失了。阅读documentation (特别是 Working with generic types
部分),我无法真正弄清楚如果它具有已知的通用类型,我将如何构造一个列表字段,例如,如果它是另一个 POJO。假设我有以下 POJO:
public class Dummy {
private String name;
//getters, setters
}
我想创建一个字段 List<Dummy>
,我将如何完成这样的任务?
谢谢!
最佳答案
而不是提供 Class<List>
对于 defineField 方法,您可以提供 Type
. ByteBuddy 有一个帮助程序类来创建通用类型,因此您不需要自己创建一个实现。我将它放在单独的一行中以使其更加明显。
// Create List<Dummy> as Type
Generic generic = TypeDescription.Generic.Builder
.parameterizedType(List.class, Dummy.class).build();
Class<? extends Example> loaded = new ByteBuddy().subclass(Example.class)
.defineField("names", generic, Visibility.PRIVATE).make()
.load(ByteBuddyEnhancer.class.getClassLoader(), ClassLoadingStrategy.Default.INJECTION).getLoaded();
验证字段实际设置并包含通用参数的一种方法是这个测试用例
Field field = loaded.getDeclaredField("names");
Type fieldType = field.getGenericType();
Assert.assertTrue(fieldType instanceof ParameterizedType);
ParameterizedType genericFieldType = (ParameterizedType)fieldType;
Assert.assertEquals(Dummy.class, genericFieldType.getActualTypeArguments()[0]);
System.out.println(genericFieldType.getRawType());
System.out.println(genericFieldType.getActualTypeArguments()[0]);
关于java - 使用 ByteBuddy 定义具有通用类型的字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45864313/
我有一个无法修改的大型第 3 方代码库,但我需要在许多不同的地方进行微小但重要的更改。我希望使用基于 ByteBuddy 的代理,但我不知道如何使用。我需要替换的调用的形式为: SomeSystemC
我正在尝试在 bytebuddy 中创建一个抽象类的子类,并想用我自己的函数覆盖构造函数。我不能让它与 defineConstructor 一起工作。 父类(super class): public
如何将 byte-buddy 生成的类与“org.reflections”一起使用? 例子: Class dynamicType = new ByteBuddy() .
我正在尝试更改已加载类的方法的返回值。 从 ByteBuddy 的文档 (http://bytebuddy.net/#/tutorial) 看来,只要我不添加任何字段/方法,这似乎可以使用 Java
我正在尝试使用 ByteBuddy 附加到我的计算机上运行的正在运行的进程。我希望在附加到正在运行的程序时,我的代理将导致重新加载已加载的类并显示我的 Transformer 的打印语句。 相反,当我
我正在尝试使用 ByteBuddy 重新定义 2 个方法,如下所示: ClassLoader classLoader = ClassLoader.getSystemClassLoader(); Cla
如何使用 AgentBuilder 将子类与名称匹配? 我可以轻松匹配类型本身 new AgentBuilder.Default() .type(named("SomeClass"))
我正在尝试与字节伙伴一起模仿模拟创建。是否可以一次性拦截所有方法? 我尝试了以下方法: new ByteBuddy() .subclass(Object.class) .method(na
我正在尝试编写一个如下所示的通用方法: private static Class immutableVersionOfClass(Class clazz) { return new Byte
我有一个带有方法 m() 的类 A 和带有方法 n() 的类 B。在 A 中,我有一个 B 类型的字段 b。在 m() 中的某个时刻会调用 b.n()。我需要使用 ByteBuddy 更改 A 的代码
我有一堆在普通 JDK 上运行的 Web 服务,我需要拦截所有公共(public)方法才能执行某些操作。一些方法使用@WebParam 注释。使用 ByteBuddy 对 WebService 进行子
如果我有以下内容: public abstract class Parameterized { protected abstract String foo(); } 是否可以这样做: Dynami
语境 我正在使用 ByteBuddy 实现字节码转换,操作过程是一个多步骤过程。 因此,操作必须能够: 扩充原有方法 完全创建新方法 扩充通过 2 引入的方法。 对于 1. 我使用了 @OnMetho
我目前正在尝试制作一个记录器代理,我目前正在拦截 PrepareStatement 类。在 PrepareStatement 中,有多种我希望跟踪的方法,但我感觉我做错了。 通常我现在所做的是拦截我希
我已经使用 ByteBuddy 库有一段时间了,但我发现自己陷入了困境。当测试的类位于同一个文件中(作为静态内部类)时,我可以使用此方法,但现在我已将逻辑分离到一个单独的文件中,它不再起作用。 如果有
如何定义一个方法,然后用 ByteBuddy 装饰它(多次)?这是我的例子 Builder builder = new ByteBuddy().subclass(Object.class).name(
有没有办法使用 ByteBuddy 为没有空构造函数的类创建代理? 这个想法是为给定的具体类型创建一个代理,然后将所有方法重定向到处理程序。 此测试展示了为没有空构造函数的类创建代理的场景,它会抛出
我正在尝试使用 bytebuddy 为进程附加代理。我发现我们可以使用 ByteBuddyAgent.attach(file,"18467");为了这。但是当我尝试执行此操作时,发生了以下错误。 这是
我正在尝试开发一个需要使用注释的工具。一个重要的功能是定位带有注释的元素并更改其值,即 // from this @Annotation(value = "foo") class SomeClass
我正在使用 Byte Buddy 1.9.0 作为基于 Xtext 的编程语言的代码生成器,并且我正在努力为实例化“匿名”类的方法生成字节码。出于所有意图和目的,我试图让 Byte Buddy 创建一
我是一名优秀的程序员,十分优秀!