Dalvik指令集

类型

语法 含义
V void,只用于返回值类型
Z boolean
B byte
S short
C char
I int
J long
F float
D double
L Java类类型
[ 数组类型

方法

方法格式:Lpackage/name/ObjectName;->MethodName(III)Z

Lpackage/name/ObjectName 所属类

MethodName 方法名

III 方法的参数(三个整型参数)

Z 方法的返回类型(boolean类型)

字段(变量)

Lpackage/name/ObjectName;->FieldName:Ljava/lang/String;

Lpackage/name/ObjectName 所属类

FieldName 字段名

Ljava/lang/String; 字段类型

空操作指令

nop

数据操作指令

返回指令

数据定义指令

数据定义指令用来定义程序中用到的常量、字符串、类等数据。基础字节码为const

"const/4vA,#+B" 将数值符号扩展为32位后赋给寄存器vA。

"const/16 VAA,#+BBBB" 将数值符号扩展为32位后赋给寄存器vAA。

"const vAA,#+BBBBBBBB" 将数值赋给寄存器vAA。

"const/hight16 vAA,#+BBBB0000" 将数值右边零扩展为32位后赋给寄存器vAA。

#"const-wide/16 vAA,#+BBBB" 将数值符号扩展为64位后赋给寄存器对vAA。

#"const-wide/32 vAA,#+BBBBBBBB" 将数值符号扩展为64位后赋给寄存器对vAA。

"const-wide vAA,#+BBBBBBBBBBBBBBBB" 将数值赋给寄存器对vAA。

"const-wide/high16 vAA,#+BBBB000000000000" 将数值右边零扩展为64位后赋给寄存器对vAA

"const-string vAA,[email protected]" 通过字符串索引构造一个字符串并赋给寄存器vAA。

"const-class vAA,[email protected]" 通过类型索引获取一个类引用并赋给寄存器vAA。

"const-class/jumbo vAAAA,[email protected]" 通过给定的类型索引获取一个类引用并赋给寄存器vAAAA。这条指令占用俩个字节,值为0x00ff(Android 4.0 新增)

锁指令

实例操作指令

数据操作指令

异常指令

跳转指令

比较指令

字段操作指令

方法调用指令

调用类实例的方法,基础指令为invoke

形式:"invoke-king{vC,vD,vE,vF,vG},[email protected]"和"invoke-kind/range{vCCCC..vNNNN},[email protected]"

后者在设置参数寄存器时使用了range来指定寄存器的范围。

"invoke-virtual"或"invoke-virtual/range" 调用实例的虚方法。

"invoke-super"或"invoke-super/range" 调用实例的父方法。

"invoke-direct"或"invoke-direct/range" 调用实例的直接方法。

"invoke-static"或"invoke-static/range" 调用实例的静态方法。

"invoke-interface"或"invoke-interface/range" 调用实例的接口方法。

Android4.0新增"invoke-kind/jumpbo{vCCCC..vNNN},[email protected]"—寄存器值与指令的索引取值范围更大。

方法调用的返回值必须使用move-result*指令来获取。

invoke-static{},Landroid/os/Parcel;->obtain()Landroid/os/Parcel;

move-resule-object v0

数据转换指令

数据运算指令

AA

时间: 2024-10-29 02:37:09

Dalvik指令集的相关文章

[转载]Dalvik指令集

这篇文章是转载的,为了便于查找一些指令,贴在这里. 转自:http://blog.csdn.net/canfengxiliu/article/details/20144119 --------------------- 声明 : 文章是看<<Android软件安全与逆向分析>>的所写笔记. Dalvik指令格式 一段Dalvik汇编代码由一系列Dalvik指令组成,指令语法由指令的位描述与指令格式标识来决定.位描述约定如下: ● 每16位的字采用空格分隔开来. ● 每个字母表示4位

用Dalvik指令集写个java类

Dalvik指令集 .class public LCalculate;#定义类名 .super Ljava/lang/Object;#定义父类 .method public static main([Ljava/lang/String;)V#申明静态main()方法,L表示这是一个类 .registers 5   #方法中使用5个寄存器 .prologue  #代码起始指令 nop #空指令 nop nop nop new-instance v0, LCalculate;   #构造一个Calc

dalvik版本的hello world(转)

本文是 Dalvik指令集 的小练习 新建一个文本文件改名为HelloWorld.smali,然后写出HelloWorld类的程序代码如下 [java] view plain copy print? .class public LHelloWorld;    #定义类名 .super Ljava/lang/Object;    #定义父类 .method public static main([Ljava/lang/String;)V    #声明静态main()方法 .registers 4 

Dalvik指令分析(一) 字节码转换为smali代码

有过android应用反编译或者再打包的朋友都有使用过apktool的经验,apktool能将dex文件的 字节码转换为smali代码,这个工具是怎么做到对dex进行解析并生成smali代码的呢?这就需要对 dex文件的格式很熟悉.需要掌握dalvik指令的字节码格式,并能翻译成对应的smali代码. 我准备写一系列的文章来分析dex文件的格式.dalvik字节码的格式.以及dex to smali的方法, 基于此可以做很多的应用,比如安全扫描.应用加固等等! Dalvik指令介绍请参考官方文档

Android逆向基础----Dalvik字节码

参考此微博,更多详细内容可以到这里查看 http://blog.csdn.net/dd864140130/article/details/52076515 Dalvik字节码 1.寄存器位32位,64位数据(double)用两个相邻的32寄存器表示. 2.两种类型:基本类型和引用类型(对象和数组) 全限定名是什么? 以String为例,其完整名称是Java.lang.String,那么其全限定名就是java/lang/String;,即java.lang.String的"."用&quo

安卓移动逆向(三)-Android Dalvik虚拟机

大家都知道Java程序是运行在Java虚拟机上,Android程序呢? 虽然Android平台使用Java语言来开发应用程序,但是Android程序却不是运行在标准的Java虚拟机上的. Google为Android平台专门设计了一套虚拟机来运行Android程序–Dalvik Virtual Machine,也就是Dalvik虚拟机了 本篇作用: 扫盲Dalvik虚拟机 了解Smail的语法,能读懂Smail文件 Dalvik概述 Dalvik的特点(相对于JVM) 体积小,占用内存小; 专有

【Android Dalvik虚拟机好学易用系列】之二:Dalvik汇编语言

一 Dalvik指令格式 1.1 位描述 Dalvik汇编代码由Dalvik指令组成,指令语法由指令的位描述与指令格式辨识来决定.位描述的约定如下所示: 每16位的字采用空格分隔开来: 每个字母表示四位,每个字符顺序从高字节开始,排列到低字节,每四位之间可能使用"|"来表示不同的内容. 顺序采用A~Z的单个大写字母作为一个4位操作码,op表示一个8位的操作码: "?"表示这字段所有位为0值. 举例,如以下指令: A|G|op BBBB F|E|D|C 两个空格:每个

Android: samil语法指令集-基于dex文件结构的寄存器虚拟机

Smali文件结构解   Smali文件与java中的类是一一对应的,包括内部类和匿名内部类也会生成对应的smali文件(典型的比如实现某个接口的匿名内部类),所以你会看到.smali文件比.java文件更多. smali文件是由Dalvik指令组成的,它有自己的一套规则,它的指令都是以“.”开头,常用的指令如下: 指令  说明 .class  包名+类名 .super  父类类名 .source  源文件名称 .implements  接口实现 .field  定义字段 .method/.en

关于 Android Dex 方法限制的一些总结

原文地址:http://greenrobot.me/devpost/about-android-dex-method-number-limit/ Android的编译过程 在了解这个问题之前我们先要来看看Android 应用编译的过程: IDE中的资源打包工具 (Android Asset Packaging Tool ,即图中的aapt) 会将应用中的资源文件进行编译,这些资源文件包括 AndroidManifest.xml文件,为Activity定义的 XML 文件等等.在这个编译过程中也会