我们应该能够以某种方式做到这一点。我想我在某个地方见过它,但我找不到我认为我记得的东西。我主要想看看编译器如何解释代码。
除了反编译,还有什么方法可以在编译时观察它在做什么吗?我认为看到它试图做什么以及在哪里可能比试图理解它的一些错误消息更容易。而且,反编译一个程序可以撤销所有解释实际发生的事情的速记和聪明。
我不知道你为什么要这样做。此外,编译结果依赖于后端,您没有指定后端。无论如何,使用--Target=
参数,您可以获得中间结果。最有用的是:
$ perl6 --target=parse -e 'say "foo"'
- statementlist: say "foo"
- statement: 1 matches
- EXPR: say "foo"
- args: "foo"
- arglist: "foo"
- EXPR: "foo"
- value: "foo"
- quote: "foo"
- nibble: foo
- longname: say
- name: say
- identifier: say
- morename: isa NQPArray
- colonpair: isa NQPArray
--target=parse显示解析的即时结果。
$ perl6 --target=ast -e 'say "foo"'
- QAST::CompUnit :W<?> :UNIT<?>
[pre_deserialize]
- QAST::Stmt
- QAST::Stmt
- QAST::Op(loadbytecode)
- QAST::VM
[jvm]
- QAST::SVal(ModuleLoader.class)
[moar]
- QAST::SVal(ModuleLoader.moarvm)
- QAST::Op(callmethod load_module)
*snip*
--Target=ast
显示抽象语法树。
$ perl6 --target=mast -e 'say "foo"'
MAST::Frame name<<unit-outer>>, cuuid<2>
Local types: 0<obj>, 1<obj>, 2<obj>, 3<obj>,
Outer: <none>
Instructions:
[0] MAST::Op getcode
MAST::Local index<3>
MAST::Frame name<<unit>>, cuuid<1>
[1] MAST::Op capturelex
MAST::Local index<3>
[2] MAST::Op getcode
MAST::Local index<1>
MAST::Frame name<<unit>>, cuuid<1>
[3] MAST::Op takeclosure
*snip*
和--target=mast
显示正在生成的实际字节码,在这种情况下是为MoarVM后端生成的。
我正在反编译一个谷歌chrome扩展,因为它看起来很可疑。扩展是用javascript编写的,但有人能告诉我像这样的符号到底是什么,以及如何将它们“翻译”回正常的字符串吗? “\x63\x68\x61\x72\x43\x6F\x64\x65” 完整文件的Jsbin:http://Jsbin.com/onevira/1/
问题内容: 我可以使用什么程序反编译类文件?我实际上会得到Java代码,还是仅仅是JVM汇编代码? 关于此站点上的Java性能问题,我经常看到“反编译” Java类文件以了解编译器如何优化某些东西的人们的回答。 问题答案: 有一些反编译器…快速搜索结果: Procyon: open-source (Apache 2) and actively developed Krakatau: open-so
IDEA有一个很棒的内置功能-反编译器。它工作得很好。我可以复制源代码,但我找不到将所有反编译的java类提取到java文件的选项 这个项目有很多java类和包,所以我很想手动复制它 有人知道如何提取到java源文件吗。谢谢
问题内容: 您可以推荐用于Eclipse的Java反编译器吗?我的其他问题是,使用来自其他Java程序的反编译代码有什么限制?非法还是什么?我对许可证知之甚少。谢谢阅读。 问题答案: 我建议在Google上弹出一个JD Java反编译器。它真的很好。 至于限制,您必须阅读特定软件的许可,否则可能会写明禁止任何反编译方式。
问题内容: 我正在使用Java开发应用程序,但是我不会发布代码。问题是,我测试了其中的一个jar反编译器,它几乎可以完美地从我的jar文件中获取代码!我的问题是如何在不提取代码的情况下分发jar文件? 问题答案: 由于Java在编译过程中保留了大多数“元数据”(允许动态加载和反射),因此直接编译(不仅反汇编)已编译的类文件是一种直接的方法。这就是为什么恢复的代码与原始代码非常相似的原因。 虽然不是