- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用 dex 文件的 Smali/Baksmali 汇编器/反汇编器来了解 DalvikVM 指令。
来自这个java文件
package gd;
class Hello {
public static void main(String[] args)
{
System.out.println("Hello!");
}
}
我生成了以下 smali 汇编文件:
.class Lgd/Hello;
.super Ljava/lang/Object;
.source "Hello.java"
# direct methods
.method constructor <init>()V
.registers 1
.prologue
.line 3
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method public static main([Ljava/lang/String;)V
.registers 3
.parameter
.prologue
.line 6
sget-object v0, Ljava/lang/System;->out:Ljava/io/PrintStream;
const-string v1, "Hello!"
invoke-virtual {v0, v1}, Ljava/io/PrintStream;->println(Ljava/lang/String;)V
.line 7
return-void
.end method
我的问题是关于以下行的。
sget-object v0, Ljava/lang/System;->out:Ljava/io/PrintStream;
据我了解,这会将 java.lang.System
类的静态对象 PrintStream
加载到 v0
寄存器中。现在,这个 out:
是什么意思?
最佳答案
PrintStream实际上是正在加载的东西的类型。您正在加载的对象可能称为 java.lang.System.out
,其中 java.lang
是包,System
是类,out
是要加载的成员(静态字段)。
您可以在invoke-virtual中看到相同的模式:java.io
是包,PrintStream
是类,println
是成员(在本例中为实例方法)。在这两种情况下,成员前面都有 ->
。我不知道这个模式在整个 Smali 中是否一致。
我找到了http://source.android.com/tech/dalvik/dalvik-bytecode.html当我玩 dalvik 的东西时,它的值(value)是无价的,尽管在本例中它的贡献只是识别 sget-object 仅接受两个参数。这告诉我 ->out:
业务必须是静态字段引用的一部分。
关于java - DalvikVM 操作码的 Smali 语法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11671545/
我在 smali 中有这行代码 :cond_2 sput-boolean v11, Lcom/geo/main/MainActivity;->mLARGE:Z 我想直接给v11赋一个True值 我该怎
我收到以下 dalvikvm 验证程序错误: Line 1041: W/dalvikvm( 2610): VFY: register1 v5 type 13, wanted 5 Line 1042:
我需要一个额外的寄存器来在 smali 方法中存储一个字符串。我知道 smali 代码中的寄存器逻辑(参见 https://github.com/JesusFreke/smali/wiki/Regis
.method private a()Landroid/content/Intent; .locals 5 .prologue .line 297 :try_start_0 iget-object v
我需要将此指令转换为 smali 代码: Uri uri = Uri.parse("http://www.google.com"); // missing 'http://' will cause c
我正在尝试生成基于 .smali 文件的调用图。然而,我遇到了一个令人困惑的案例如下: .super Landroid/graphics/drawable/Drawable; .source "SBa
.method public c()Ljava/lang/String; .locals 3 const/4 v1, 0x0 const-string v0, "wifi" invoke-virtua
我有一个 smali 代码,我想在其中的一开始就注入(inject)一个 sleep 函数。为此,我创建了一个只是 hibernate 的应用程序,生成了它的 smali 并作为 onCreate 方
按照 smali 代码,通过单击查看按钮在 web View 中查看 url。但链接后面是结果 url 中的 PackageName 。那么我应该在以下 smali 代码中更改什么才能仅转到链接?
我注入(inject)了这段代码invoke-static {p0}, Lcom/outfit7/talkingtomcandyrun/Toast;->show(Landroid/content/Co
smali 中的这一行是做什么的?我一直在谷歌上搜索 .restart 的东西,但没能找到任何关于它的信息。 .restart local v3 #i:I 最佳答案 这相当于 dex 文件
我使用 baksmali 反汇编了一个 Android 应用程序,并研究了生成的smali代码。其中一个类包含以下行: .local v1, "future":Lcom/android/volley/
我对一些 android apk 进行了逆向工程,以添加一些用于功能测试的工具。我想知道给定一个 smali,如下所示,我该如何添加类似 的内容 Log.e(TAG, "some descritpio
我一直在研究 smali 中的一个简单方法(此处来自 Android),我想知道如何对它做一些简单的事情,比如 return false。我一直在尝试通过与 Java 对应物比较和一些示例来理解它,我
是否存在 .smali 文件的解析器? 让我更明确一点: 我需要编写一个程序。 这个程序的输入是一个.smali文件。 这个程序(感谢我的解析器寻找 ) 应该在每次声明全局变量时捕获。 下一步添加一些
我知道如何从函数返回 TRUE bool 值: .locals 1 const/4 v0, 0x1 return v0 现在我需要返回一个整数(10000 值)。怎么办? 最佳答案 下面的方法 pub
我使用 apktool 将 .dex 解码为 smali,但我找不到编辑 DEBUG 的方法,DEBUG 是一个默认为 false 的 boolean 值(在 Java 字节码编辑器中读取 0x000
我对apk文件进行逆向工程,发现AlertDialog is cancelable false invoke-virtual {v0, v4}, Landroid/app/AlertDialog$Bu
我正在逆向一个 Android 应用程序。我想修改并重建它。我使用APK Studio(这几乎是 apktool 的 GUI 版本)来获取 apk 中的文件。现在阅读 smali 代码非常困难。 我还
序言 我正在尝试使用 dex 文件的 Smali/Baksmali 汇编器/反汇编器来了解 DalvikVM 指令。 问题 来自这个java文件 package gd; class Hello {
我是一名优秀的程序员,十分优秀!