- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我只想为带有公共(public)或 protected 字段、构造函数和方法的 java 类生成字节码。
我正在尝试使用以下代码,但我不知道 这是正确的方法吗?
Client code:
String sourceFileName = file.getName();
ClassReader reader = new ClassReader(file.getContents());
ClassWriter writer = new ClassWriter(ClassWriter.COMPUTE_FRAMES);
JavaStubClassAdapter adapter = new JavaStubClassAdapter(writer, sourceFileName);
reader.accept(adapter, 0);
byte[] content = writer.toByteArray();
// we can use content to print in .class file
Adapator code:
private class JavaStubClassAdapter extends ClassVisitor {
private final String sourceFileName;
/**
* @param writer
* @param sourceFileName
*/
public JavaStubClassAdapter(ClassWriter writer, String sourceFileName) {
super(Opcodes.ASM7, writer);
this.sourceFileName = sourceFileName;
}
@Override
public void visitSource(String source, String debug) {
super.visitSource(this.sourceFileName, null);
}
@Override
public FieldVisitor visitField(int access, String name, String descriptor, String signature, Object value) {
if (access == Opcodes.ACC_PUBLIC || access == Opcodes.ACC_PROTECTED) {
return super.visitField(access, name, descriptor, signature, value);
}
return null;
}
@Override
public MethodVisitor visitMethod(int access, String name, String descriptor, String signature,
String[] exceptions) {
if (access == Opcodes.ACC_PUBLIC || access == Opcodes.ACC_PROTECTED) {
return super.visitMethod(access, name, descriptor, signature, exceptions);
}
return null;
}
}
最佳答案
下面的代码对我有用
Client code this method has
org.eclipse.core.resources.IFile
ClassReader reader = new ClassReader(file.getContents());
if (!isAccessPermited(reader.getAccess())) {
return new byte[0];
}
ClassWriter writer = new ClassWriter(ClassWriter.COMPUTE_FRAMES);
JavaStubClassAdapter adapter = new JavaStubClassAdapter(writer, sourceFileName);
reader.accept(adapter, 0);
return writer.toByteArray();
Helper methods
private static boolean isAccessPermited(final int access) {
boolean isEnumAcc = (access & Opcodes.ACC_ENUM) == 0 ? false : true;
boolean isPublicAcc = (access & Opcodes.ACC_PUBLIC) == 0 ? false : true;
boolean isProtectedAcc = (access & Opcodes.ACC_PROTECTED) == 0 ? false : true;
if (isPublicAcc || isProtectedAcc || isEnumAcc) {
return true;
}
return false;
}
private static boolean isFinalAccess(final int access) {
return (access & Opcodes.ACC_FINAL) != 0;
}
Adapator code
private static class JavaStubClassAdapter extends ClassVisitor {
private final String sourceFileName;
/**
* @param writer
* ClassVisitor
* @param sourceFileName
* String
*/
public JavaStubClassAdapter(ClassVisitor writer, String sourceFileName) {
super(Opcodes.ASM7, writer);
this.sourceFileName = sourceFileName;
}
@Override
public void visitSource(String source, String debug) {
super.visitSource(this.sourceFileName, null);
}
@Override
public FieldVisitor visitField(int access, String name, String descriptor, String signature, Object value) {
if (isAccessPermited(access)) {
switch (descriptor) {
case "Ljava/lang/String;": //$NON-NLS-1$
if (isFinalAccess(access)) {
return super.visitField(access, name, descriptor, signature, "");
}
return super.visitField(access, name, descriptor, signature, null);
case "Z": //$NON-NLS-1$
return super.visitField(access, name, descriptor, signature, Boolean.FALSE);
case "C": //$NON-NLS-1$
case "B": //$NON-NLS-1$
case "S": //$NON-NLS-1$
case "I": //$NON-NLS-1$
case "J": //$NON-NLS-1$
case "D": //$NON-NLS-1$
case "F": //$NON-NLS-1$
if (isFinalAccess(access)) {
return super.visitField(access, name, descriptor, signature, Integer.valueOf(0));
}
return super.visitField(access, name, descriptor, signature, null);
case "Ljava/lang/Object": //$NON-NLS-1$
return super.visitField(access, name, descriptor, signature, null);
default:
return super.visitField(access, name, descriptor, signature, null);
}
}
return null;
}
@Override
public MethodVisitor visitMethod(int access, String name, String descriptor, String signature,
String[] exceptions) {
if (isAccessPermited(access)) {
MethodVisitor mv = super.visitMethod(access, name, descriptor, signature, exceptions);
return new JavaClassEmptyMethodVistor(mv, Type.getReturnType(descriptor));
}
return null;
}
@Override
public void visitInnerClass(String name, String outerName, String innerName, int access) {
if (isAccessPermited(access)) {
super.visitInnerClass(name, outerName, innerName, access);
}
}
}
private static class JavaClassEmptyMethodVistor extends MethodVisitor {
private final MethodVisitor visitor;
private final Type returnType;
public JavaClassEmptyMethodVistor(MethodVisitor methodVisitor, Type type) {
super(Opcodes.ASM7, methodVisitor);
this.visitor = methodVisitor;
this.returnType = type;
}
@Override
public void visitMethodInsn(int opcode, String owner, String name, String descriptor, boolean isInterface) {
// Do nothing
}
@Override
public void visitFieldInsn(int opcode, String owner, String name, String descriptor) {
// Do nothing
}
@Override
public void visitInsn(int opcode) {
if (returnType == Type.INT_TYPE || returnType == Type.FLOAT_TYPE
|| returnType == Type.LONG_TYPE || returnType == Type.DOUBLE_TYPE
|| returnType == Type.CHAR_TYPE || returnType == Type.BYTE_TYPE ) {
visitor.visitIntInsn(Opcodes.BIPUSH, 0);
visitor.visitInsn(Opcodes.IRETURN);
} else if (returnType == Type.BOOLEAN_TYPE) {
visitor.visitInsn(Opcodes.ICONST_0);
visitor.visitInsn(Opcodes.IRETURN);
} else if (returnType == Type.VOID_TYPE) {
visitor.visitInsn(Opcodes.RETURN);
} else {
visitor.visitInsn(Opcodes.ACONST_NULL);
visitor.visitInsn(Opcodes.ARETURN);
}
}
@Override
public void visitIincInsn(int var, int increment) {
// Do nothing
}
@Override
public void visitLineNumber(int line, Label start) {
// Do nothing
}
@Override
public void visitLabel(Label label) {
// Do nothing
}
@Override
public void visitTypeInsn(int opcode, String type) {
// Do nothing
}
@Override
public void visitJumpInsn(int opcode, Label label) {
// Do nothing
}
@Override
public void visitLdcInsn(Object value) {
// Do nothing
}
@Override
public void visitVarInsn(int opcode, int var) {
// Do nothing
}
@Override
public void visitMaxs(int maxStack, int maxLocals) {
visitor.visitMaxs(0, 0);
}
@Override
public void visitLookupSwitchInsn(Label dflt, int[] keys, Label[] labels) {
// Do nothing
}
@Override
public void visitTableSwitchInsn(int min, int max, Label dflt, Label... labels) {
// Do nothing
}
@Override
public void visitTryCatchBlock(Label start, Label end, Label handler, String type) {
// Do nothing
}
@Override
public void visitFrame(int type, int numLocal, Object[] local, int numStack, Object[] stack) {
// Do nothing
}
}
关于java - 操作从 ASM 生成的字节码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62464896/
我需要处理来自旧 Mac 时代(旧摩托罗拉 CPU)的文件。字节是大端字节序,所以我有一个函数可以将 Int64 交换为英特尔小端字节序。该函数是 ASM,可在 32 位 CPU 上运行,但不能在 6
1.概述 转载:史上最通俗易懂的ASM教程 一勺思想 We are all in the gutter, but some of us are looking at the stars. (我们都生活
1.概述 转载:ASM 与 Presto 动态代码生成简介 代码生成是很多计算引擎中常用的执行优化技术,比如我们熟悉的 Apache Spark 和 Presto 在表达式等地方就使用到代码生成技术。
我想在 C++ 程序中使用 ASM 调用地址为 774a7fdch 的函数(kernel32.dll 函数) 我正在使用 Visual Studio 2010。 我该怎么做? call 774a7fd
我是否正确转换了它? 原始 VS C++ 版本: _TEB *pTeb = NULL; _asm { mov eax, fs:[0x18];
阅读自howto_add_systemcall "In general, header files for machine architecture independent system calls
在实现无锁数据结构和时序代码时,通常需要抑制编译器的优化。通常人们使用 asm volatile 和 clobber 列表中的 memory 来执行此操作,但有时您只会看到 asm volatile
这个“strcpy”函数的目的是将src的内容复制到dest,结果很好:显示两行“Hello_src”。 #include static inline char * strcpy(char * de
我正在尝试进行一些汇编编码,我从 C 语言调用函数。代码本身运行良好,但我有两个巨大的问题在很长一段时间内无法解决。第一个是语法高亮 - 我安装了两个不同的(当时一个)asm 高亮扩展到 Visual
我正在研究一些类文件分析,并且正在研究使用 ASM 来读取类。在 Javap 中,操作码以及 tagName 和 tagValue 是内联打印的,但在每个 AbstractInsnNode 中,我只看
我正在尝试弄清楚如何将 ASM 中的 DB 变量用于内联 ASM C++ 我有这个 ASM 代码: filename db "C:\imagen.bmp" eti0: mov ah,3dh mov a
这个“strcpy”函数的目的是将src的内容复制到dest,结果很好:显示两行“Hello_src”。 #include static inline char * strcpy(char * de
在 mm/memory.c 中,它包含一个文件: #include tlb.h 是 include/asm-generic/tlb.h或 arch/arm/include/asm/tlb.h ? 最
你好我找到了一个asm代码......它被集成到c++项目中 template T returned; BYTE *tem = buffer; __asm { mov eax, tem
问题:当我运行 @ 命令提示符 >tasm HelloWorld.asm 顺便说一句,我在输入文件名 HelloWorld.asm 时使用 TAB,所以没有错字.我收到这个致命的命令行错误: Turb
尝试通过 eax 从 asm proc 返回一个 long int,后来又尝试通过 dx:ax。两者都不适合我,因为 C printf 打印的数字与所需的 320L 不同。 x.asm: .model
这是 godbolt 生成的代码. 下面是 Visual Studio 在我的 main.asm 文件上生成的相同代码(通过 Project->C/C++->Output Files->Assembl
在构建具有依赖项的 giraph jar 时,我们收到以下警告.. 真的不知道如何解决这些.. 我们已经尝试过了 useProjectArtifact 为 false 和 解压为真 两者似乎都有效 任
我正在使用 gentoo 并尝试编译一个程序来控制并行端口上的位。它的顶部附近有这条线: #include 当我尝试在其上使用 gcc 时,它会产生以下输出: port.c:4:20: error:
(原帖)将 hibernate 依赖项添加到 pom.xml 时显示错误 2011-10-11 10:36:53.710::WARN: failed guiceFilter java.lang.No
我是一名优秀的程序员,十分优秀!