- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我启动并运行了 Byte Buddy 作为代理,它成功拦截了我的绝大部分代码库,顺便说一句,它相当大!虽然有一些我无法检测的异常值,但我在下面记录了这些异常值,希望您可能知道答案!
<强>1。 CGLIB 生成的类
Spring 生成一些额外的类,这些类与我的类同名,但在末尾附加了 "$$EnhancerByCGLIB$$"
,这些会导致错误。我得到的错误是:
java.lang.IllegalStateException: Cannot resolve type description for com.mycompany.MySpringBean$$EnhancerByCGLIB$$ee9d3c37_2
at net.bytebuddy.pool.TypePool$Resolution$Illegal.resolve(TypePool.java:152)
at net.bytebuddy.pool.TypePool$LazyFacade$LazyResolution$LazyTypeDescription.resolve(TypePool.java:3158)
at net.bytebuddy.pool.TypePool$LazyFacade$LazyResolution$LazyTypeDescription.getModifiers(TypePool.java:3238)
at net.bytebuddy.ByteBuddy.rebase(ByteBuddy.java:697)
事实上,我对检测 CGLIB 生成的类没有兴趣,因此希望排除这些。什么是最好的方法?目前,我正在按名称匹配,但我想知道这是否是最好的方法。
.and(not(nameContains("EnhancerByCGLIB")))
<强>2。包私教私教课
我看到的另一个问题是对 package private
或 private class
进行检测。
Package private
代码如下所示:
abstract class BaseBean {
Object methodA(final String customerNumber){}
}
我得到的错误是:
Caused by: java.lang.IllegalAccessException:
Class net.bytebuddy.implementation.LoadedTypeInitializer$ForStaticField cannot
access a member of class com.mycompany.BaseBean with modifiers "public static"
私有(private)类
代码如下:
public class Object A {
//variables & methods...
private class ObjectB {}
}
我得到的错误是:
Caused by: java.lang.IllegalAccessException:
Class net.bytebuddy.implementation.LoadedTypeInitializer$ForStaticField cannot
access a member of class com.mycompany.ObjectA$ObjectB with modifiers "public static"
Byte Buddy 可以检测 package private
或 private classes
吗?
<强>3。沉默失败
这只是一个一般性问题,但是否可以指示 Byte Buddy 在每个类上静默失败?这样一来,任何此类错误都不会阻止应用程序启动或 Byte Buddy 尽可能多地检测。
<强>4。公共(public)抽象类中的公共(public)方法
我的代码是这样的:
package com.mycompany;
public interface InterfaceA{
Object provideAccess(final String id);
}
package com.mycompany;
public abstract class BaseBeanA implements InterfaceA {
//some general helper methods
}
package com.mycompany;
public abstract class BaseBeanB extends BaseBeanA {
//some specific helper methods
}
package com.mycompany;
public class BeanImpl extends BaseBeanB {
protected Object provideAccess(final String id) {
}
}
这会导致在检测 BaseBeanB 时出现以下错误:
java.lang.IllegalArgumentException: None of [protected void java.lang.Object.finalize() throws java.lang.Throwable, public final native void java.lang.Object.wait(long) throws java.lang.InterruptedException, public final void java.lang.Object.wait() throws java.lang.InterruptedException, public final void java.lang.Object.wait(long,int) throws java.lang.InterruptedException, public boolean java.lang.Object.equals(java.lang.Object), public java.lang.String java.lang.Object.toString(), public native int java.lang.Object.hashCode(), public final native java.lang.Class java.lang.Object.getClass(), protected native java.lang.Object java.lang.Object.clone() throws java.lang.CloneNotSupportedException, public final native void java.lang.Object.notify(), public final native void java.lang.Object.notifyAll(), public java.lang.Object com.mycompany.MyInterceptor.intercept(java.util.concurrent.Callable,java.lang.Object[],java.lang.reflect.Method,java.lang.Class) throws java.lang.Exception] allows for delegation from public abstract Object com.mycompany.InterfaceA.provideAccess(java.lang.String)
最佳答案
<强>1。 CGLIB 生成的类
您的解决方案是正确的。事实上,按名称指定类对性能总是有好处的。例如,如果您可以排除整个包,Byte Buddy 甚至可以在不解析类文件的情况下丢弃一个类,因为名称是单独可用的。
检测 cglib 生成的类失败的原因是这些类没有可用的字节码。
<强>2。包私教&私教课
你在这里发现了一个错误。我最近重构了这个逻辑,通过公开它们来不需要合成字段的可访问性,但我只是忘记了包私有(private)字段。这已在 master 分支上修复,将在 0.7-rc7 中发布。
<强>3。沉默失败
如果检测失败,这个失败总是报告给 AgentBuilder.Listener
。除此之外,失败没有任何影响,因为它是由 ClassFileTransformer
API 暗示的。您是否观察到任何通过的异常?您可能还想查看对监听器 AgentBuilder
进行重大重构的最新版本。
<强>4。公共(public)抽象类中的公共(public)方法
您的拦截器定义了一个 Callable
类型的参数,我假设它由 SuperCall
注释。这会注入(inject)一个代理来调用被拦截方法的 super 方法(如果存在)。对于像您试图拦截的抽象方法,这是行不通的,Byte Buddy 决定您的拦截器不可绑定(bind)。因此抛出异常。
也就是说,通过将 Object 类型的方法排除在委托(delegate)之外,Byte Buddy 不考虑将它们用于委托(delegate)。这会提高性能。
关于java - 使用 Byte Buddy 的检测问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33412774/
我有以下代码: foreach (byte b in bytes) { byte inv = byte.MaxValue - b; // Add the new value to a
我需要从这个文本文件source.txt中读取内容并将内容反向写入这个文本文件destination.txt。读取和写入必须使用逐字节完成! 我使用 BufferedReader 和 Buffered
我需要存储大量 RGB 颜色对象。对于某些常见用途,这些占用了我的应用程序总内存的 8% 到 12%。我目前将其定义如下: class MyColor { byte red; byte green;
我有一个由字节数组表示的整数。 byte[] result = getResult(); resultInt1 = Integer.parseInt(Bytes.toString(result));/
我正在尝试使用 Rusoto 库调用 AWS Lambda 函数。该请求有一个 JSON 编码的有效负载,我目前将其作为一个字符串,但该库为此坚持使用 bytes::bytes::Bytes 结构。我
我正在尝试基于 Tokio's example 编写一个 TCP 服务器. 当我尝试发送缓冲区时,编译器返回错误 0277。 我的代码:(playground) extern crate tokio;
我知道我可以通过 IList 进行枚举,例如: public byte[] ConvertToByteArray(IList> list) { IList newList = new List
考虑这样一个文本文件: Some text here. --- More text another line. --- Third part of text. 我想把它分成三部分,用---分隔符分开。
如果我有一个字节变量:byte b = 0; 为什么以下工作: b++; b += 1; // compiles ...但这不是吗? b = b + 1; // compile er
我有一个简单的字节数组,我想从中获取颜色。我的计划是用红色表示三位,绿色表示三位,蓝色表示两位。 8 位。 我认为颜色是正确的: 如有错误请指正 byte[] colours = new byte[
我的目标是比较两个字节数组中的两个字符串值。它实际上需要创建两个新的字符串对象才能使用 contains 方法。是选择正确还是有什么办法可以使用优化方式而不使用新的关键字。 if(new String
我正在使用github.com/tarm/serial来连接一些串行仪器。在开发过程中,我使用/dev/ttyp0和/dev/ptyp0对,其中go进程连接到一个,我使用screen连接到另一个。我编
好的,所以如果一个字节是 8 位,那么半字节就是 4 位。并且您可以将四分之一字节作为 2 位(尽管我想,如果有的话,它会被称为双位)。 虽然这是一致的,但如果我使用这个词,有人会感到困惑(或惊讶)吗
我在解释文件时遇到问题。文件构建如下: "name"-@-"date"-@-"author"-@-"signature" 签名是一个字节数组。当我读回文件时,我将其解析为 String 并拆分它: m
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 10 年前。 Improve thi
Java 让我很难过,因为它需要 ArrayList 的包装类秒。我将如何添加 byte[]到 ArrayList ? 最佳答案 LOL 认为我必须包装所有东西。 ArrayList作品。谢谢一晒。
我有一个 16 字节的 md5 散列,我需要使用 XOR 将其“折叠”成 4 字节数据:{1st 4 bytes} XOR {2nd 4 bytes} XOR {3rd 4 bytes} XOR {4
我正在学习SMSC smc91cx驱动代码,我学习了如何根据Application Note 9-6的说明编写smc91c111网卡的测试代码。 .我无法理解“传输数据包”下的以下说明: Write
我必须附加(可变数量的)字节数组。集合似乎只适用于包装类,即 Byte。大约 20 小时后,我想到了这个,并且它有效,但我想知道它是否可以改进(添加到列表,但欢迎任何其他改进建议:),即 Collec
我有两个基本相同的操作: insert_bytes(from, count) delete_bytes(start, stop) -> delete_bytes(from, count) insert
我是一名优秀的程序员,十分优秀!