编译java文件相关知识
-
Java逆向基础之AspectJ的ajc与aj5命令acj命令是用于编译java文件和aj文件的编译器,相当于eclipse的编译器(ECJ)+aspectj运行时扩展aj5命令在jdk1.5上使用-javaagent:pathto/aspectjweaver.jar加载aspectj程序,达到修改字节码的目的这两个命令可以用java命令和javac来替代,我们以上文的命令为例Load-time weaving (LTW) 加载时编织编译ajc -outjar myjar.jar HelloWorld.javaajc -outjar MyAspect.jar -outxml MyAspect.aj -classpath "myjar.jar;%CLASSPATH%"运行aj5 -classpath "MyAspect.jar;myjar.jar;%CLASSPATH%" HelloWorl
-
jvm是如何执行i = i++ + ++i的,你知道吗?结果是多少?public static void main(String[] args) { int i = 0; i = i++ + ++i; System.out.println(i); }//结果输出 2为什么是2?一个.java文件首先要被编译成.class文件jvm才能够运行,而jvm是根据java代码生成的字节码来确认他要如何运行程序的。说的再通俗一点就是,jvm看不懂java代码,他能看懂的是字节码,而编译就是这么一个翻译的过程。 所以为了了解i = i++ + ++i的运行原理,我们首先反汇编这段代码(请先编译java文件,Main.java是我的文件名):在命令行下输入javap -c Main.class可以看到字节码
-
jvm是如何执行i = i++ + ++i的,你知道吗?结果是多少?public static void main(String[] args) { int i = 0; i = i++ + ++i; System.out.println(i); }//结果输出 2为什么是2?一个.java文件首先要被编译成.class文件jvm才能够运行,而jvm是根据java代码生成的字节码来确认他要如何运行程序的。说的再通俗一点就是,jvm看不懂java代码,他能看懂的是字节码,而编译就是这么一个翻译的过程。 所以为了了解i = i++ + ++i的运行原理,我们首先反汇编这段代码(请先编译java文件,Main.java是我的文件名):在命令行下输入javap -c Main.class可以看到字节码
-
Java 源代码编译成 Class 文件的过程分析原文链接:http://www.codeceo.com/article/compile-java-source-code-into-a-class-file.html在上篇文章《Java三种编译方式:前端编译 JIT编译 AOT编译》中了解到了它们各有什么优点和缺点,以及前端编译+JIT编译方式的运作过程。下面我们详细了解Java前端编译:Java源代码编译成Class文件的过程;我们从官方JDK提供的前端编译器javac入手,用javac编译一些测试程序,调试跟踪javac源码,看看javac整个编译过程是如何实现的。1、javac编译器1-1、javac源码与调试javac编译器是官方JDK中提供的前端编译器,JDK/bin目录下的javac只是一个与平台相关的调用入口,具体实现在JDK/lib目录下的tools.jar。此外,JDK6开始提供在运行时进行前端编译,默认也是调用到javac,如图:javac是由Java语言编写的,而HotSpot虚拟机则是由C++语言编写;标准JDK中并没有提供java
编译java文件相关课程
编译java文件相关教程
- 1.1 Java 中的编译 在 Java 中,程序不是直接被编译为可执行文件,而是被编译为字节码文件, JVM(Java虚拟机)在运行时执行字节码文件。当我们使用 javac 编译器时,Java 源代码文件被编译为字节码文件,字节码文件以扩展名 .class 的形式保存在磁盘上。当程序运行时,字节码文件将被转换为机器代码,并在内存中执行。总的来说,Java 源代码需要被“转换”两次才能被计算机执行:Java 源代码被编译为字节码:由 javac 前端编译器完成;字节码被编译为机器码:由 JVM 的执行引擎完成。下图描述了一个Java程序从编写到编译,再到执行的步骤:
- 2.1 编译 编译语法aapt2 compile path-to-input-files [options] -o output-directory/在以下示例中,AAPT2 分别编译了名为 strings.xml 和 myImage.png 的资源文件:aapt2 compile project_root/module_root/src/main/res/values-en/strings.xml -o compiled/aapt2 compile project_root/module_root/src/main/res/drawable/myImage.png -o compiled/如上表中所示,输出文件的名称取决于输入文件的名称及其父目录(资源类型和配置)的名称。对于以 strings.xml 作为输入的上述示例,aapt2 会自动将输出文件命名为 values-en_strings.arsc.flat。另一方面,存储在 drawable 目录中的已编译可绘制对象文件的文件名将为 drawable_img.png.flat。编译选项命令选项说明-o指定已编译资源的输出路径。–dir指定要在其中搜索资源的目录。–pseudo-localize生成默认字符串的伪本地化版本,如 en-XA 和 en-XB。–no-crunch停用 PNG 处理。–legacy将使用早期版本的 AAPT 时允许的错误视为警告。-v启用详细日志记录。
- 5. Kotlin反编译插件的使用 AndroidStudio 和 IntelliJ IDEA 一样,也有 Kotlin 的反编译插件神器,有了它就能更加清晰理解 Kotlin 语法糖背后的原理了。1. 首先来给activity_main.xml布局中那个 TextView 加个 id:2. 然后在MainActivity中,直接使用tv_hello来改变文本内容,因为在app/build.gradle加入了apply plugin: 'kotlin-android-extensions',再也不需要像 Java 那样手动的findviewById。是不是觉得 Kotlin 超级方便,简单,没有任何模板代码。3. 可能很多人都会疑惑,为什么 Kotlin 却能做到不需要 findViewById 呢? Kotlin 编译器到底在背后默默做了哪些事?所以这时候需要轮到 Kotlin 反编译插件上场,通过它你将会发现 Kotlin 背后做了哪些骚操作。反编译工具的使用和 IntelliJ IDEA 是一样的。4. 点击Show Kotlin Bytecode后,将会看到代码区域右边,会出现一个Kotlin Bytecode区域,这里面显示的 Kotlin 字节码:5. 然后点击Kotlin Bytecode区域中的Decompile反编译按钮,它能将Kotlin字节码反编译成对应的Java代码:6. 然后在代码区域将会出现MainActivity.decompiled.java反编译后的 Java 代码:
- TypeScript 编译选项 TypeScript 提供了很多不同功能的编译选项,既可以通过配置 tsconfig.json 文件中的 compilerOptions 属性来实现编译,也可以使用在 tsc 命令后跟随参数这形式,直接编译 .ts 文件。注意: 当命令行上指定了输入文件时,tsconfig.json 文件会被忽略。
- 5. Kotlin 反编译插件的使用 关于第一个 Hello Kotlin 大家可以会疑惑一点,特别是有 Java 基础的小伙伴心里会想为什么 Kotlin 的 main 函数定义可以脱离类包裹,在类外面直接定义函数运行,这一点在 Java 中是做不到的呀。想知道为什么吗? 那么接下来就由 Kotlin 反编译插件这个神器来告诉你。(强调一点,关于反编译插件后续会频繁反复用到,一定要学会如何使用)。下面就是使用反编译插件的基本使用步骤:1. 在主界面中,找到Tools中的Kotlin,然后找到Kotlin中的Show Kotlin Bytecode:2. 点击Show Kotlin Bytecode后,将会看到代码区域右边,会出现一个Kotlin Bytecode区域,这里面显示的Kotlin字节码:3. 然后点击Kotlin Bytecode区域中的Decompile反编译按钮,它能将Kotlin字节码反编译成对应的Java代码:4. 然后在代码区域将会出现HelloKotlin.decompiled.java反编译后的 Java 代码:到这里大家应该恍然大悟,有Java基础的小伙伴都能看懂,这就是一个HelloKotlinKt类中定义一个main函数。其实 Kotlin 那么简单 main 函数本质上还是一个类包裹,只不过 Kotlin 给你提供更简洁的写法。实际上 Kotlin 中的 main 函数是一个顶层函数,顶层函数会对应默认生成一个类,类名默认是定义的 Kotlin 文件名 +Kt 后缀;然后函数对应类中的静态函数。至于什么是顶层函数以及类名生成规则后面会陆续讲到。
- 4. 编译库 如果你正在开发一个供其他 Kotlin 应用程序使用的库,那么可以构建 .jar 文件,而不将 Kotlin 运行时包含在其中。kotlinc hello.kt -d hello2.jar可以通过 jar 查看工具来看:相比下面这种运行时方式编译后的产物是不一样的,下面包含一个运行时打包:kotlinc hello.kt -include-runtime -d hello.jar可以通过 jar 查看工具来看:由于以这种方式编译的二进制文件依赖于 Kotlin 运行时,因此无论何时使用编译库,都应确保后者存在于类路径中。还可以使用 kotlin 脚本来运行 Kotlin 编译器生成的二进制文件:kotlin -classpath hello.jar HelloKt # HelloKt 是 Kotlin 编译器为名为 hello.kt 的文件生成的主类名。
编译java文件相关搜索
-
back
backbone
background
background attachment
background color
background image
background position
background repeat
backgroundcolor
backgroundimage
background属性
badge
bash
basics
basis
bat
bdo
bean
before
begintransaction