- 浏览: 882423 次
- 性别:
- 来自: 深圳
文章分类
- 全部博客 (509)
- android (55)
- CSS (23)
- eclipse (25)
- Data Structes and Algorithms (53)
- J2SE (87)
- Java_面试学习_j2se (26)
- java_面试学习_非技术 (13)
- java_gui (2)
- java_设计模式 (27)
- JDBC (10)
- java_web (15)
- hibernate (5)
- Oracle (37)
- Struts2 (7)
- Word-----dos (24)
- Jbpm (3)
- java小技巧 (8)
- math (1)
- flex (12)
- WebService (4)
- 生活 (9)
- 小框架或小语言 (27)
- spring (1)
- 面试~~~软实力 (7)
- jstat的用法 (1)
- jmap (1)
- 数据链路层和传输层的流量控制区别 (1)
- shell (0)
- 财商 (1)
- javascript (0)
- js研究 (1)
- 代码收集 (0)
最新评论
-
海尔群:
http://jingyan.baidu.com/articl ...
android加密 -
完美天龙:
------------------------- ...
asm----字节码操纵 -
houniao1990:
大神,请问 string 类型 定义为 oracle的 cha ...
hibernate注解 -
JamesQian:
Line:103
f.doFilter(msg);
是否需 ...
责任链模式_过滤器模式 -
sacoole:
好评
interview--- 如何从N个数中选出最大(小)的n个数?
目的:
程序分析:用于分析程序,动态生成proxy等。
程序生成:可在内存中生成java类并编译,所谓的just in time complie
程序转换:优化程序插入debugging或平台观察代码(AOP)
ASM库提供生成、转换类的2种API,一直API是基于事件一种是基于数的。基于事件的就类似于xml的SAX,而基于树的就像DOM.这2种API都有各自的有点与缺点。基于事件的API快速并且需要的内存比基于树的少。
组织结构:
org.objectweb.asm与org.objectweb.asm.signature是定义基于事件的API并提供了class的读写组建。
org.objectweb.asm.util是工具包。
org.objectweb.asm.commons定义了预定义类的转行器
org.objectweb.asm.tree定义了基于树的API
org.objectweb.asm.tree.analysis定义了基于树API的分析框架和预定义类的分析器
java字节码的结构
+----------------------------------------------------+
|Modifiers, name, super class, interfaces |
+----------------------------------------------------+
|Constant pool: numeric, string and type constants |
+----------------------------------------------------+
|Source file name (optional) |
+----------------------------------------------------+
|Enclosing class reference |
+----------------------------------------------------+
|Annotation* |
+----------------------------------------------------+
|Attribute* |
+----------------------------------------------------+
|Inner class* Name |
+----------------------------------------------------+
|Field* Modifiers, name, type |
| Annotation* |
| Attribute* |
+----------------------------------------------------+
|Method* Modifiers, name, return and parameter types |
| Annotation* |
| Attribute* |
| Compiled code |
+----------------------------------------------------+
内部名
在class文件里面使用的是内部名,如String的内部名是 java/lang/String
类型描述:
java类型->类型描述
boolean->Z
char->C
byte->B
short->S
int->I
float->F
long->J
double->D
Object->Ljava/lang/Object;
int[]->[I
Object[][]->[[Ljava/lang/Object;
方法描述:
方法描述是类型描述列表,用于描述方法的参数类型以及返回值类型
方法声明->方法描述
void m(int i, float f)->(IF)V
int m(Object o)->(Ljava/lang/Object;)I
int[] m(int i, String s)->(ILjava/lang/String;)[I
Object m(int[] i)->([I)Ljava/lang/Object;
生成和解析编译好的类文件是基于ClassVisitor接口。这个接口的每个方法对应类文件相同的段名如下:
public interface ClassVisitor {
void visit(int version, int access, String name, String signature,
String superName, String[] interfaces);
void visitSource(String source, String debug);
void visitOuterClass(String owner, String name, String desc);
AnnotationVisitor visitAnnotation(String desc, boolean visible);
void visitAttribute(Attribute attr);
void visitInnerClass(String name, String outerName, String innerName,
int access);
FieldVisitor visitField(int access, String name, String desc,
String signature, Object value);
MethodVisitor visitMethod(int access, String name, String desc,
String signature, String[] exceptions);
void visitEnd();
}
使用方法必须符合下面规则:
visit visitSource? visitOuterClass? ( visitAnnotation | visitAttribute )*
( visitInnerClass | visitField | visitMethod )*
visitEnd
visit必须是第一个被调用的方法,然后调用visitOuterClass,接着调用visitAnnotation和visitAttribute依次类推,最后调用visitEnd
ASM提供3个核心基于ClassVisitor的3个核心组件用于产生解析类:
1、ClassReader解析已经编译好的类文件,调用对应的VisitXxx方法
2、ClassWriter实现了ClassVisitor接口,生成类
3、ClassAdapter实现了ClassVisitor接口,代理调用接口的所有方法
以下是类解析的例子相关信息,通过Visitor打印类
来看看ClassReader,要了解ClassReader.
首先要理解要理解Class文件定义的格式
struct Class_File_Format {
u4 magic_number; //4个字节的魔幻数 是16进制的0xcafe 0xbabe cafe呵呵有点好耍
u2 minor_version; //2个字节的主版本号
u2 major_version; //2个字节次版本号
u2 constant_pool_count; //常量池大小
cp_info constant_pool[constant_pool_count - 1]; //常量池信息
u2 access_flags; //类或接口访问表示
u2 this_class; //本类在常量池的索引
u2 super_class; //父类在常量池的索引
u2 interfaces_count; //接口计数
u2 interfaces[interfaces_count]; //接口对应常量池的索引
u2 fields_count; //类的域个数
field_info fields[fields_count]; //域数据,包括属性名称索引,域修饰符掩码等
u2 methods_count; //方法计数
method_info methods[methods_count]; //方法信息
u2 attributes_count; //类附加属性个数
attribute_info attributes[attributes_count];//类附加属性数据,包括源文件名等。
};
看看常量表cp_info的定义。
cp_info {
u1 tag;
u1 info[];
}
cp_info的tag保存着类型信息,如下:
类型 值
CONSTANT_Class 7
CONSTANT_Fieldref 9
CONSTANT_Methodref 10
CONSTANT_InterfaceMethodref 11
CONSTANT_String 8
CONSTANT_Integer 3
CONSTANT_Float 4
CONSTANT_Long 5
CONSTANT_Double 6
CONSTANT_NameAndType 12
CONSTANT_Utf8 1
指定的类型又显示了info指向的每种结构,比如CONSTANT_Class这种类型的指向的结构是
CONSTANT_Class_info {
u1 tag;
u2 name_index;
}
以下是Class_File_Format的结构图
程序分析:用于分析程序,动态生成proxy等。
程序生成:可在内存中生成java类并编译,所谓的just in time complie
程序转换:优化程序插入debugging或平台观察代码(AOP)
ASM库提供生成、转换类的2种API,一直API是基于事件一种是基于数的。基于事件的就类似于xml的SAX,而基于树的就像DOM.这2种API都有各自的有点与缺点。基于事件的API快速并且需要的内存比基于树的少。
组织结构:
org.objectweb.asm与org.objectweb.asm.signature是定义基于事件的API并提供了class的读写组建。
org.objectweb.asm.util是工具包。
org.objectweb.asm.commons定义了预定义类的转行器
org.objectweb.asm.tree定义了基于树的API
org.objectweb.asm.tree.analysis定义了基于树API的分析框架和预定义类的分析器
java字节码的结构
+----------------------------------------------------+
|Modifiers, name, super class, interfaces |
+----------------------------------------------------+
|Constant pool: numeric, string and type constants |
+----------------------------------------------------+
|Source file name (optional) |
+----------------------------------------------------+
|Enclosing class reference |
+----------------------------------------------------+
|Annotation* |
+----------------------------------------------------+
|Attribute* |
+----------------------------------------------------+
|Inner class* Name |
+----------------------------------------------------+
|Field* Modifiers, name, type |
| Annotation* |
| Attribute* |
+----------------------------------------------------+
|Method* Modifiers, name, return and parameter types |
| Annotation* |
| Attribute* |
| Compiled code |
+----------------------------------------------------+
内部名
在class文件里面使用的是内部名,如String的内部名是 java/lang/String
类型描述:
java类型->类型描述
boolean->Z
char->C
byte->B
short->S
int->I
float->F
long->J
double->D
Object->Ljava/lang/Object;
int[]->[I
Object[][]->[[Ljava/lang/Object;
方法描述:
方法描述是类型描述列表,用于描述方法的参数类型以及返回值类型
方法声明->方法描述
void m(int i, float f)->(IF)V
int m(Object o)->(Ljava/lang/Object;)I
int[] m(int i, String s)->(ILjava/lang/String;)[I
Object m(int[] i)->([I)Ljava/lang/Object;
生成和解析编译好的类文件是基于ClassVisitor接口。这个接口的每个方法对应类文件相同的段名如下:
public interface ClassVisitor {
void visit(int version, int access, String name, String signature,
String superName, String[] interfaces);
void visitSource(String source, String debug);
void visitOuterClass(String owner, String name, String desc);
AnnotationVisitor visitAnnotation(String desc, boolean visible);
void visitAttribute(Attribute attr);
void visitInnerClass(String name, String outerName, String innerName,
int access);
FieldVisitor visitField(int access, String name, String desc,
String signature, Object value);
MethodVisitor visitMethod(int access, String name, String desc,
String signature, String[] exceptions);
void visitEnd();
}
使用方法必须符合下面规则:
visit visitSource? visitOuterClass? ( visitAnnotation | visitAttribute )*
( visitInnerClass | visitField | visitMethod )*
visitEnd
visit必须是第一个被调用的方法,然后调用visitOuterClass,接着调用visitAnnotation和visitAttribute依次类推,最后调用visitEnd
ASM提供3个核心基于ClassVisitor的3个核心组件用于产生解析类:
1、ClassReader解析已经编译好的类文件,调用对应的VisitXxx方法
2、ClassWriter实现了ClassVisitor接口,生成类
3、ClassAdapter实现了ClassVisitor接口,代理调用接口的所有方法
以下是类解析的例子相关信息,通过Visitor打印类
package com.appspot.coder9527; import java.io.IOException; import org.objectweb.asm.AnnotationVisitor; import org.objectweb.asm.Attribute; import org.objectweb.asm.ClassReader; import org.objectweb.asm.ClassVisitor; import org.objectweb.asm.FieldVisitor; import org.objectweb.asm.MethodVisitor; public class ClassInfoVisitor implements ClassVisitor { @Override public void visit(int version, int access, String name, String signature, String superName, String[] interfaces) { System.out.println(name + " extends " + superName + " {"); } @Override public AnnotationVisitor visitAnnotation(String desc, boolean visible) { return null; } @Override public void visitAttribute(Attribute attr) { } @Override public void visitEnd() { System.out.println("}"); } @Override public FieldVisitor visitField(int access, String name, String desc, String signature, Object value) { System.out.println(" " + desc + " " + name); return null; } @Override public void visitInnerClass(String name, String outerName, String innerName, int access) { } @Override public MethodVisitor visitMethod(int access, String name, String desc, String signature, String[] exceptions) { System.out.println(" " + name + desc); return null; } @Override public void visitOuterClass(String owner, String name, String desc) { } @Override public void visitSource(String source, String debug) { } public static void main(String argv[]) throws IOException { ClassReader reader = new ClassReader("com.appspot.coder9527.ClassInfoVisitor"); ClassInfoVisitor visitor = new ClassInfoVisitor(); reader.accept(visitor, 0); } }
来看看ClassReader,要了解ClassReader.
首先要理解要理解Class文件定义的格式
struct Class_File_Format {
u4 magic_number; //4个字节的魔幻数 是16进制的0xcafe 0xbabe cafe呵呵有点好耍
u2 minor_version; //2个字节的主版本号
u2 major_version; //2个字节次版本号
u2 constant_pool_count; //常量池大小
cp_info constant_pool[constant_pool_count - 1]; //常量池信息
u2 access_flags; //类或接口访问表示
u2 this_class; //本类在常量池的索引
u2 super_class; //父类在常量池的索引
u2 interfaces_count; //接口计数
u2 interfaces[interfaces_count]; //接口对应常量池的索引
u2 fields_count; //类的域个数
field_info fields[fields_count]; //域数据,包括属性名称索引,域修饰符掩码等
u2 methods_count; //方法计数
method_info methods[methods_count]; //方法信息
u2 attributes_count; //类附加属性个数
attribute_info attributes[attributes_count];//类附加属性数据,包括源文件名等。
};
看看常量表cp_info的定义。
cp_info {
u1 tag;
u1 info[];
}
cp_info的tag保存着类型信息,如下:
类型 值
CONSTANT_Class 7
CONSTANT_Fieldref 9
CONSTANT_Methodref 10
CONSTANT_InterfaceMethodref 11
CONSTANT_String 8
CONSTANT_Integer 3
CONSTANT_Float 4
CONSTANT_Long 5
CONSTANT_Double 6
CONSTANT_NameAndType 12
CONSTANT_Utf8 1
指定的类型又显示了info指向的每种结构,比如CONSTANT_Class这种类型的指向的结构是
CONSTANT_Class_info {
u1 tag;
u2 name_index;
}
以下是Class_File_Format的结构图
发表评论
-
jqplot参数描述
2012-10-17 10:20 2741jqPlot 图形报表插件简介及参数详解(jquery) ... -
Apache 代理(Proxy)
2012-08-16 17:23 1726代理分为:正向代理(Foward Proxy)和反向代理(Re ... -
Apache 2.2-SSL操作大全
2012-08-11 20:06 1587制作CSR申请文件 安装证书文件 客户端证书认证 强制H ... -
HTTP返回码中301与302的区别
2012-08-11 17:04 9347一.官方说法 301,302 ... -
handlerbar
2012-08-09 17:42 1408安装和使用 Handlebars的 ... -
win7ppt打开两个的问题
2012-08-08 10:09 19411、引言 Excel 是我们最常用的办公软件之一,在日常工作中 ... -
xsi:schemaLocation
2012-08-05 10:57 1631在实例中引用模式文档 XML Schema提供了两个在实例 ... -
sublime text 快捷键
2012-07-28 10:40 1177快捷键 XP版 Ctrl+L 选择整行 ... -
webx常用标签收集
2012-07-10 09:59 1228#set($spmHome="/static&quo ... -
java调用domino
2012-06-20 17:52 1274java访问操作lotus domino数据库 有几种方式: ... -
Lotus Domino/Notes Toolkits 综述(注:转)
2012-06-20 17:04 1616http://wind-bell.iteye.com/blog ... -
notes数据库api
2012-06-20 16:42 1866用Java远程操作Domino服务器的例子 1.服务器必 ... -
cron
2012-06-09 09:15 2681上一文中提到 Cron触发 ... -
quartz与mysql连接 持久化
2012-06-07 10:10 4505Mysql相关软件: MySQL-server-communi ... -
quartz
2012-06-06 19:14 1509http://blog.csdn.net/bibitoo712 ... -
史上最简! Subvision SVN (svn的服务器端) 安装教程
2012-04-19 10:02 1302由于 indian 写的Subvision安装教程实在是太好了 ... -
反编译还原总结
2011-12-11 15:06 2026java class 利用jad 反编译之后,偶尔回碰到一 ... -
svn命令
2011-07-18 19:34 1433svn命令 通常都有帮助,可通过如下方式查询: $ svn ... -
maven-----概念
2011-06-28 14:32 1567常用maven命令 mvn clean install -Ds ... -
svn编程
2011-06-02 20:24 1681API文档: http://svnkit.com/jav ...
相关推荐
7. **教程与学习资源**:"ASM4使用指南.pdf"文件应包含了关于如何启动ASM4,创建第一个模型,进行建模操作,运行模拟以及解读分析结果等内容。这份指南是学习和掌握ASM4的关键资源,建议用户按照指南逐步实践。 8. ...
本文将详细解读ASM1053和ASM1153E这两款器件的数据手册,帮助读者深入理解它们的功能特性,以及在USB到SATA桥接应用中的作用。 ASM1053和ASM1153E是由领先的半导体制造商设计的USB到SATA桥接芯片,主要用于实现USB...
【描述解读】:描述中提到“Asm转com不支持伪指令”,意味着这个asm2com工具在处理汇编语言源代码时,可能不处理或无法识别那些不是实际机器指令的伪指令(Pseudo-Opcodes)。伪指令在汇编语言中用于简化编程,它们...
为了充分利用C32Asm,用户应熟悉汇编语言的基础知识,理解C32格式的特性,以及掌握如何解读反汇编后的代码。此外,对于软件开发者而言,理解逆向工程的道德和法律边界也是十分重要的,因为逆向工程可能涉及到版权和...
这个过程对于软件开发人员来说至关重要,因为原始的二进制代码对于人类来说几乎无法直接解读。而通过反汇编,开发者可以更好地理解第三方库、研究恶意软件的工作原理,或者优化程序性能。 文件名“W32DASM中文”...
以下是对ASM这一高级Java技术的详细解读: 1. **ASM框架概述** ASM是一个轻量级的库,提供了对Java字节码的低级别访问。它能够直接操作字节码,从而可以用于创建、加载或修改类。ASM提供了两种主要的API:Class...
根据提供的文件内容,我们可以了解到ASM公司生产的几款...上述内容基于文件提供的信息进行了合理猜测,旨在提供一种对于文件内容的解读。如果需要准确的产品信息,应直接咨询ASM公司或访问其官方网站获取最准确的数据。
**描述解读:** 描述中提到,“W32asm无极版,bug很少,我觉得用过的版本这个是最好的吧”,这表明该版本在用户体验方面表现出色,相对其他版本来说,它的错误或问题较少,可能是用户认为最优秀的W32asm版本。用户...
以下是对"oracle centos7 asm依赖包"的详细解读: 1. **ASM介绍**:Oracle ASM是一种集成的文件系统和卷管理器,它提供了自动化的磁盘管理和数据存储功能。ASM能够自动平衡数据,提供故障检测和恢复,以及无缝地...
5. **Proteus仿真**:Proteus软件在电路设计和程序调试中的应用,如何建立电路模型,加载代码并进行运行和测试,以及如何解读仿真结果。 6. **实验学习法**:通过实践来学习单片机原理和编程,每个实验可能涉及特定...
8. **CJX6.ASM**:这个文件名可能代表一种特定的硬件模块或功能,如计数器、定时器等,具体功能需要根据代码内容来解读。 通过这些项目,学生可以全面锻炼其分析问题、解决问题的能力,提升单片机系统的实际设计和...
3. **README**:此文件提供了MyPerf4J的使用指南和相关说明,包括安装步骤、配置示例以及如何解读监控数据等。对于初学者来说,是快速上手的关键参考资料。 MyPerf4J的特点在于其轻量级和低侵入性。由于使用了ASM,...
#### 标题解读 ASM AD8930是一款专门针对高速银浆固晶工艺设计的自动化设备,其操作手册旨在指导操作人员掌握正确的操作流程,有效应对可能遇到的故障,确保设备稳定运行,提升生产效率和产品质量。 #### 描述详解 ...
下面对这段代码进行详细解读: #### ORG指令 ```assembly ORG 0000H AJMP MAIN ORG 0000H ``` 这里使用了两次`ORG`指令,其中第一次设置程序的起始地址为0000H,第二次同样设置为0000H可能是笔误。`AJMP MAIN`则...
下面将对关键代码段进行解读: 1. **内存分配与初始化**: ```asm mov @dwDigit, eax ; 需要的位数 add eax, 4 mov @dwCalLen, eax ; 计算长度 ... invoke GlobalAlloc, GMEM_MOVEABLE or GMEM_ZEROINIT, eax...
下面我们将对这个压缩包中的内容进行详细的解读。 首先,我们看到有两个文件——"Var.bat"和"Readme.txt"。"Var.bat"通常是一个批处理文件,可能用于设置环境变量或执行一系列命令,以便于源码的编译和运行。而...
本文将依据ASM1153E的Datasheet,对这款芯片进行详细的解读,帮助读者深入了解其工作原理和应用潜力。 首先,ASM1153E是一款三通道、低电压、高速串行至并行转换器,它能够将串行数据流转换为并行格式,以满足高速...
- **内存解读**:解释了如何从不同的角度解析内存中的数据,这对于理解数据类型转换等概念非常重要。 #### 三、编写第一个程序 第三章是本书的核心之一,它引导读者完成第一个汇编语言程序的编写。在这个过程中,...
在描述中提到的“asm, util, 2.2, jar.zip包下载, 依赖包”关键词,我们可以解读如下: 1. **asm**:ASM是这个库的核心,它是Java字节码操纵和分析框架。ASM提供了一种直接在类文件级别操作的方法,可以用来创建、...
《反编译助手C32asm深度解析》 在IT领域,反编译是一种重要的技术手段,它允许我们查看和理解已...通过掌握这款工具的使用,我们可以提升对二进制代码的解读能力,从而在编程、调试、安全检测等多个方面提升工作效率。