【安卓逆向】smali基础(一)

如果你不相信努力和时光,那么成果就会是第一个选择辜负你的。不要去否定你自己的过去,也不要用你的过去牵扯你现在的努力和对未来的展望。不是因为拥有希望你才去努力,而是去努力了,你才有可能看到希望的光芒。【安卓逆向】smali基础(一),希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

Dalvik指令集

  • 寄存器的定义
    • .locals 定义寄存器的数量
  • 函数的定义
    • .method 函数的开始
    • end 函数的结束
  • 数据操作指令
    • move vA,vB 将vB寄存器的值赋予vA寄存器
    • move/16 vAA,vBB 定义了数据宽度为16位
    • move-object vA,vB 用于对象赋值
    • move-object/16 vAA,vBB定义数据宽度
  • 返回指令
    • return vAA 返回vAA寄存器的值
    • return-object 返回对象
  • 数据的定义指令
    • const 数据定义
    • const-string 定义一个字符串
  • 实例操作指令
    • check-cast vAA,type@BB将vAA寄存器的对象引用转换成指定类型
    • instance-of vA,vB,type@CC 将判断vB寄存器的对象引用是否可以转换为指定类型,是vA=1,反正vA=0
    • new-instance vAA,type@AAA 构造一个指定类型的新实例
  • 数组操作指令
    • array-length vA,vB获取vB寄存器中的数组长度,结果赋予vA寄存器
    • new-array vA,vB,type@CC 构造指定类型和大小(vB)的数组,结果赋予vA
  • 异常
    • throw vAA 抛出vAA寄存器中指定类型的异常
  • 指令跳转
    • goto 无条件跳转
    • packed-switch vAA,+BB 分支跳转指令,+BB只想递增偏移表
    • sparse-switch vAA,+BB 分支跳转,无规律
  • if跳转指令
    • if-test
      • eq 等于
      • ne 不等于
      • lt 小于
      • le小于等于
      • ge 大于大于
      • gt 大于
      • nez 不等于0
      • nqz 等于0
  • 比较指令
    • cmp-float 比较两个单精度浮点数
    • cmp-double 比较双精度浮点数
    • cmp-long 比较两个长整型
  • 字段操作
    • 普通字段以”i”开头
      • iget 读操作
      • iput 写操作
    • 静态字段以”s”开头
      • sget 读操作
      • sput 写操作
  • 方法调用
    • invoke-virtual 调用实例虚方法
    • invoke-super 调用实例的父类方法
    • invoke-direct 调用实例的直接方法
    • invoke-static 调用实例的静态方法

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/206296.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!