smali的文件语法格式

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/water_3700348/article/details/82781521

无论是普通类、抽象类、接口类或者内部类,在反编译出来的代码中,他们都以单独的smali文件来存放。

一、smali文件的头3行描述了当前类的一些信息,格式如下:

.class <访问权限>[修饰关键字]<类名> 
.super <父类名>                     
.source <源文件名>

类名开头的L是遵循Dalvik字节码的相关约定,表示后面跟随的字符串为一个类,经过混淆的dex文件,反编译出来的smali代码可能没有源文件信息,因此,.source行可能为空。

二、smali文件中,字段的声明使用“.field”指令

  • 静态字段格式:
#static fields
.field <访问权限> static[修饰关键字]<字段名>:<字段类型>
  • 实例字段格式:
#instance fields
.field <访问权限> static[修饰关键字]<字段名>:<字段类型>

三、smail文件中,方法的声明使用“.method”指令,方法有直接方法与虚方法。

  • 直接方法声明格式:
#direct methods
.method <访问权限>[修饰关键字]<方法原型>
<.locals>		//置顶了使用的局部变量的个数
[.parameter]		//多个参数则有多个[.parameter]
[.prologue]		//指定了代码的开始处,混淆过的代码可能去掉了该指令
[.lime]			//置顶了该处指令在源代码中的行号,混淆过的代码可能去除了行号
<代码体>
.end method
  • 虚方法的声明格式:
#virtual methods
.method <访问权限>[修饰关键字]<方法原型>
<.locals>		//置顶了使用的局部变量的个数
[.parameter]		//多个参数则有多个[.parameter]
[.prologue]		//指定了代码的开始处,混淆过的代码可能去掉了该指令
[.lime]			//置顶了该处指令在源代码中的行号,混淆过的代码可能去除了行号
<代码体>
.end method

四、如果类实现了接口,在smali文件中使用“.implements”,格式如下:

#interfaces
.implements <接口名>

五、如果类使用了注解,在smali文件中使用“.annotation”,格式如下:

#annotations
.annotatiion[注解属性]<注解类名>
	[注解字段 = 值]
.end annotation

注解的作用范围可以是类、方法或字段。如果注解的作用方位是类,“.annotation”指令会直接定义在文件中,如果是方法或字段,“.annotation”指令则包含在方法或字段定义中。

猜你喜欢

转载自blog.csdn.net/water_3700348/article/details/82781521
今日推荐