当前位置: 首页 > news >正文

鸿蒙OpenHarmony[Disassembler反汇编工具]ArkTS运编译工具链

简介

Disassembler是ArkTS反汇编工具,如果开发者需要分析方舟字节码文件(*.abc)相关问题,可使用Disassembler将字节数据反汇编成可阅读的汇编指令。

工具随DevEco Studio SDK发布,以windows平台为例,Disassembler工具位置为:[DevEco Studio安装目录]\sdk[SDK版本]\openharmony\toolchains\ark_disasm.exe。

命令行说明

反汇编命令:

ark_disasm.exe [options] input_file output_file

参数说明:

参数是否可缺省描述
[options]可缺省命令选项,详见下文options选项说明。
input_file不可缺省待反汇编的方舟字节码文件路径。
output_file不可缺省反汇编内容的输出文件路径。

options选项说明:

选项是否可缺省是否存在入参描述
–debug可缺省不带参数使能输出调试信息,默认输出到屏幕。
–debug-file可缺省带参数如果使能了–debug,指定调试信息的输出文件。
–help可缺省不带参数打印帮助提示。
–skip-string-literals可缺省不带参数跳过对字符串字面量的反汇编。
–quiet可缺省不带参数使能所有’–skip-'开头的选项。
–verbose可缺省不带参数使能输出额外信息(字节位置、方舟字节码格式、操作码)。
–version可缺省不带参数显示配套方舟字节码文件版本号以及最低支持的方舟字节码文件版本。

使用示例

假设已存在方舟字节码文件:test.abc,其源代码如下:

let i = 99;
function show(){return i;}
show();

执行如下命令,就能生成反汇编文件:test.txt。生成的反汇编文件内带有操作码及格式等信息。

ark_disasm.exe test.abc test.txt

查看反汇编文件的内容。

cat test.txt

内容如下

# source binary: test.abc                                                    // 反汇编的方舟字节码文件.language ECMAScript# ====================
# LITERALS                                                                   // 字面量数据0 0x203 { 0 [MODULE_REQUEST_ARRAY: {};
]}# ====================
# RECORDS                                                                    // 模块定义数据.record _ESConcurrentModuleRequestsAnnotation {                              // _开头这些都是固定的模块数据
}.record test {                                                               // 一个js文件对应一个模块数据,包含了模块的相关信息(在方舟字节码文件中的位置,是否是commonjs ...)u8 isCommonjs = 0x0u32 moduleRecordIdx = 0x203......
}# ====================
# METHODS                                                                    // 方法定义数据L_ESSlotNumberAnnotation:u32 slotNumberIdx { 0x0 }
.function any test.#*#show(any a0, any a1, any a2) <static> {                // 此方法源码中的show方法,同时这里也说明了,它属于test模块ldlexvar 0x0, 0x0......
}L_ESSlotNumberAnnotation:u32 slotNumberIdx { 0x3 }
.function any test.func_main_0(any a0, any a1, any a2) <static> {            // 此方法是自动生成的,可以理解成整个js文件就是一个方法,方法名为func_main_0newlexenv 0x1......
}# ====================
# STRING                                                                     // 符号表信息[offset:0x88, name_value:i]

使用参数–verbose,可打印偏移量等更多详细信息。

ark_disasm.exe --verbose test.abc test.txt

此处列出部分示例。

.record _ESSlotNumberAnnotation { # offset: 0x00cd, size: 0x0026 (38)                                  // 这里打印了模块在方舟字节码文件中具体的位置和大小
}.record test { # offset: 0x00f3, size: 0x0098 (152)                                                    // 这里打印了模块在方舟字节码文件中具体的位置u32 moduleRecordIdx = 0x203 # offset: 0x0144                                                   // 这里打印了模块信息的位置
}
......
.function any test.#*#show(any a0, any a1, any a2) <static> { # offset: 0x0153, code offset: 0x0245    // 这里打印了方法信息具体的位置和方法中指令的具体位置
#   CODE:ldlexvar 0x0, 0x0 # offset: 0x0249, [IMM4_IMM4].........[0x3c 0x00]                            // 这里打印了每条指令的具体位置......
}
http://www.xdnf.cn/news/1068859.html

相关文章:

  • Webpack 核心概念
  • ubuntu22.04可以执行sudo命令,但不在sudo组
  • 通俗易懂解读BPE分词算法实现
  • 【评估指标】IoU 交并比
  • 北斗导航 | 基于CNN-LSTM-PSO算法的接收机自主完好性监测算法
  • <六> k8s + promtail + loki + grafana初探
  • 14.Linux Docker
  • JavaScript逆向工程核心技术解密:反混淆、反调试与加密破解全景指南
  • 【cursor实战】分析python下并行、串行计算性能
  • 【网站内容安全检测】之1:获取网站所有链接sitemap数据
  • 鸿蒙与h5的交互
  • 机器学习01
  • IDEA高效开发指南:JRebel热部署
  • 每日AI资讯速递 | 2025-06-25
  • Django
  • (C++)vector数组相关基础用法(C++教程)(STL库基础教程)
  • 7.Spring框架
  • TensorFlow Lite (TFLite) 和 PyTorch Mobile模型介绍1
  • 什么是功能测试和非功能测试?
  • Azure 托管 Redis 已正式发布
  • 打造属于你的AI智能体,从数据开始 —— 使用 Bright Data MCP+Trae快速构建垂直智能体
  • 【Elasticsearch】es初识,在项目架构中的用途,与mysql和kafka的配合使用,
  • linux安装docker
  • LE AUDIO---Chapter 2. The Bluetooth® LE Audio architecture
  • 记一次AWS 中RDS优化费用使用的案例
  • 【学习笔记】3.3 Decoder-Only PLM
  • 【目标检测】平均精度(AP)与均值平均精度(mAP)计算详解
  • 从数据到决策:UI前端如何利用数字孪生技术提升管理效率?
  • list的使用和模拟实现
  • 探索解析C++ STL中的 list:双向链表的高效实现与迭代器