java 编译 器 ide

最近一个名为“ 不使用IDE编译Java软件包 ”的Java subreddit线程提出了一个问题:“是否有一个命令将软件包内的一组Java文件编译到一个单独的文件夹中(以下简称为bin),以及如何我会去运行新的类文件吗?” 该帖子的作者kylolink解释说:“当我开始使用Java时,我依靠Eclipse为我完成所有编译,而只是担心编写代码。” 我已经多次看到这个问题,实际上,这是促使我(现在已经4岁)的博客文章GPS系统和IDE的原因:有用还是有害? 我喜欢强大的现代Java IDE,它们每天使我的生活变得更轻松,但是了解如何在没有它们的情况下构建和运行简单的Java示例也有很多好处。 这篇文章着重于如何做到这一点。

在我的博客文章“ 通过简单测试学习Java”中 ,我写了一些我有时喜欢使用简单的文本编辑器和命令行工具来编写,构建和运行简单应用程序的方式。 我现在有一个很好的主意,我最喜欢的Java IDE需要多少“开销”,并尽早决定使用IDE获得的好处是否足以保证“开销”。 在大多数实际应用程序中,毫无疑问,IDE“开销”是值得的。 但是,对于最简单的示例应用程序,并非总是如此。 本文的其余部分显示了在这些情况下如何在没有IDE的情况下构建和运行Java代码。

要构建和执行的Java代码

为了使本文的讨论更加具体,我将使用一些非常简单的Java类,这些Java类通过组合或继承相互关联,并且位于相同名称的包中(而不是未命名的包中 ),称为dustin.examples 。 其中两个类没有main函数,而第三个类Main.java确实具有一个main函数,以允许演示如何在没有IDE的情况下运行该类。 接下来显示这三个类的代码清单。

Parent.java

package dustin.examples;public class Parent
{@Overridepublic String toString(){return "I'm the Parent.";}
}

Child.java

package dustin.examples;public class Child extends Parent
{@Overridepublic String toString(){return "I'm the Child.";}
}

Main.java

package dustin.examples;import static java.lang.System.out;public class Main
{private final Parent parent = new Parent();private final Child child = new Child();public static void main(final String[] arguments){final Main instance = new Main();out.println(instance.parent);out.println(instance.child);}
}

下一个屏幕快照显示了具有这些类.java源文件的目录结构。 屏幕快照显示了源文件在表示包名称的目录层次结构中(由于使用dustin.examples因此使用了dustin.examples dustin/examples ),并且反映包的目录层次结构在名为src的子目录下。 我还创建了classes子目录(当前为空)来放置已编译的.class文件,因为javac该目录不存在时不会创建该目录。

使用Javac进行构建并使用Java运行

无论使用哪种方法来构建Java代码(Ant,Maven,Gradle或IDE),它最终都归结为javac 。 通过运行javac -help可以看到Oracle / Sun提供的javac 命令行工具的标准选项,而通过运行javac -help -X可以查看其他扩展选项。 在Windows或Unix / Linux的 javac的工具文档中可以找到有关如何应用这些选项的更多详细信息。

如javac文档所述, -sourcepath选项可用于表示源文件所在的目录。 在上面的屏幕快照中显示的目录结构中,这意味着,假设我正在C:\java\examples\javacAndJava\目录中运行javac命令,则我的命令中需要具有以下内容: javac -sourcepath src src\dustin\examples\*.java 。 下一个屏幕快照显示了此结果。

因为我们没有为.class文件指定目标目录,所以默认情况下将它们与编译它们的源.java文件放在同一目录中。 我们可以使用-d选项纠正这种情况。 我们的命令现在可以运行,例如,作为javac -sourcepath src -d classes src\dustin\examples\*.java 。 如前所述,指定的目标目录( classes )必须已经存在。 完成后,该命令会将.class文件放置在指定的目录中,如下一个屏幕快照所示。

将Java源文件编译为指定目录中的相应.class文件之后,我们现在可以使用Java应用程序启动器命令行工具java运行该应用程序。 只需按照java -help或java工具页面上显示的说明并使用-classpath (或-cp )选项指定.class文件的位置即可完成。 在下一个屏幕快照中演示了使用这两种方法指定classes目录是查找.class文件的位置。 最后一个参数是具有要执行的main功能的类的标准名称(整个Java程序包)。 在下一个屏幕快照中演示的命令是java -cp classes dustin.examples.Mainjava -classpath classes dustin.examples.Main

使用Ant构建并运行

对于最简单的Java应用程序,使用javacjava分别构建和执行该应用程序非常简单,如刚刚演示的那样。 随着应用程序的参与度提高(例如,存在于多个软件包/目录中的代码或第三方库和框架上更复杂的类路径依赖项),这种方法可能变得笨拙。 Apache Ant是Java构建工具“三巨头 ”中最古老的一种,已在数千个应用程序和部署中使用。 正如我在前一篇博客文章中所讨论的那样 ,很容易创建一个非常基本的Ant构建文件,尤其是如果该文件以我在该文章中概述的模板开头的话。

下一个代码清单是针对Ant build.xml文件的,该文件可用于将.java文件编译为.class文件,然后运行dustin.examples.Main类,就像上面对javacjava所做的那样。

build.xml

<?xml version="1.0" encoding="UTF-8"?>
<project name="BuildingSansIDE" default="run" basedir="."><description>Building Simple Java Applications Without An IDE</description><target name="compile"description="Compile the Java code."><javac srcdir="src"destdir="classes"debug="true"includeantruntime="false" /></target><target name="run" depends="compile"description="Run the Java application."><java classname="dustin.examples.Main" fork="true"><classpath><pathelement path="classes"/></classpath></java></target>
</project>

我没有使用过Ant属性,也没有包括我通常包含的公共目标(例如“ clean”和“ javadoc”),以使该示例尽可能简单,并使之与使用javacjava的上一个示例保持接近。 还要注意,我为javac Ant任务包括了将“ debug”设置为“ true”的原因,因为在Ant的默认设置中它不是true,而在javac的默认值中是true。 毫不奇怪,Ant的javac任务和java任务与命令工具javacjava非常相似。

因为我使用了未明确指定构建文件的Ant期望的默认名称( build.xml ),并且因为我将“运行”目标作为该构建文件的“默认”,并且因为我将“编译”作为依赖项,要运行“运行”目标,并且由于Ant在我环境的路径上,因此我需要在命令行上执行以使Ant编译并运行该示例的所有操作是在带有build.xml文件的目录中键入“ ant”。 下一个屏幕快照对此进行了演示。

尽管我演示了如何使用Ant编译和运行简单的Java应用程序,但是我通常仅使用Ant编译并使用java (或者如果类路径令人讨厌的话,会调用java的脚本)运行。

使用Maven构建和运行

尽管Ant是第一个主流的Java构建工具,但是Apache Maven最终获得了自己的显著成就,这在很大程度上要归功于它采用了约定的配置方式以及对库的通用存储库的支持。 当代码和生成的对象符合其标准目录布局时,Maven最容易使用。 不幸的是,我的示例没有遵循此目录结构,但是Maven允许我们覆盖预期的默认目录结构 。 下一个代码清单是针对Maven POM文件的,该文件将覆盖源目录和目标目录,并为使用Maven 3.2.1的Maven构建提供其他最低要求的元素。

pom.xml

<project><modelVersion>4.0.0</modelVersion><groupId>dustin.examples</groupId><artifactId>CompilingAndRunningWithoutIDE</artifactId><version>1</version><build><defaultGoal>compile</defaultGoal><sourceDirectory>src</sourceDirectory><outputDirectory>classes</outputDirectory><finalName>${project.artifactId}-${project.version}</finalName></build>
</project>

因为上面的pom.xml文件将“ defaultGoal”指定为“ compile”,并且因为pom.xml是Maven可执行文件(mvn)查找的默认自定义POM文件,并且因为Maven安装的bin目录在我的路径上,所以我只需要运行“ mvn”来编译.class文件,如下一个屏幕快照所示。

我还可以使用命令mvn exec:java -Dexec.mainClass=dustin.examples.Main使用Maven运行编译后的应用程序,这将在下一个屏幕快照中演示。

与Ant一样,我通常不使用Maven运行我的简单Java应用程序,而是在编译后的代码上使用java (或使用直接为长类路径调用java的脚本)。

使用Gradle构建和运行

Gradle是三种主要Java构建工具中最年轻,最时髦和最时髦的。 有时,我对流行趋势的实质持怀疑态度,但是我发现Gradle有很多令人喜欢的地方 (用Groovy而不是XML编写,内置的Ant支持,内置的Ivy支持,按约定容易被覆盖的配置) ,Maven存储库支持等)。 下一个示例显示了一个Gradle构建文件,该文件可用于编译和运行简单应用程序,这是本文的主要示例代码。 它改编自我在博客文章Simple Gradle Java Plugin Customization中介绍的示例。

build.gradle

apply plugin: 'java'
apply plugin: 'application'// Redefine where Gradle should expect Java source files (*.java)
sourceSets {main {java {srcDirs 'src'}}
}// Redefine where .class files are written
sourceSets.main.output.classesDir = file("classes")// Specify main class to be executed
mainClassName = "dustin.examples.Main"defaultTasks 'compileJava', 'run'

build.gradle文件的前两行指定Java插件和Application插件的应用程序 ,从而自动为该版本带来了很多功能。 “ sourceSets”和“ sourceSets.main.output.classesDir”的定义允许分别覆盖Gradle的Java插件的Java源代码和编译的二进制类的默认目录。 “ mainClassName”允许显式指定应作为Application插件的一部分运行的类。 “ defaultTasks”行通过在命令行中简单地键入“ gradle”来指定要运行的任务:“ compileJava”是Java插件提供的标准任务,“ run”是Application插件提供的标准任务。 因为我将构建文件命名为build.gradle并且因为我指定了默认任务'compileJava'和'run',并且因为我的路径上有Gradle安装bin目录,所以我要做的就是构建和运行示例。键入“ gradle”,这将在下一个屏幕快照中演示。

即使是最大的怀疑论者也不得不承认,对于这个简单的示例,Gradle的构建非常巧妙。 它结合了依靠某些约定和假设的简洁性,以及根据需要覆盖选择默认值的非常简单的机制。 它使用Groovy而不是XML的事实也非常吸引人!

与Ant和Maven一样,我倾向于仅使用这些工具进行构建,并且通常直接使用java或调用java的脚本直接运行已编译的.class文件。 顺便说一句,我通常也将这些.class存档到运行中的JAR中,但这超出了本文的范围。

结论

IDE通常对于构建简单的应用程序和示例不是必需的,甚至可能比最简单的示例值得拥有更多的开销。 在这种情况下,直接应用javacjava来构建和运行示例相当容易。 随着示例变得越来越复杂,诸如Ant,Maven或Gradle之类的构建工具变得越来越有吸引力。 许多IDE支持这些构建工具的事实意味着,如果在简单的应用程序发展成为一个成熟的项目时确定需要IDE支持,则开发人员可以使用在过程中较早创建的构建工具过渡到IDE。

翻译自: https://www.javacodegeeks.com/2014/04/compiling-and-running-java-without-an-ide.html

java 编译 器 ide

java 编译 器 ide_在没有IDE的情况下编译和运行Java相关推荐

  1. 在没有IDE的情况下编译和运行Java

    最近一个名为" 不使用IDE编译Java软件包 "的Java subreddit线程提出了一个问题:"是否有一个命令将软件包内的一组Java文件编译到一个单独的文件夹中( ...

  2. target存放的是编译后的.class文件地方 默认情况下不会讲非class文件放入进入 如果要使用非.class文件 需要通过增加配置方式自动加入文件...

    target存放的是编译后的.class文件地方 默认情况下不会讲非class文件放入进入 如果要使用非.class文件 需要通过增加配置方式自动加入文件 转载于:https://www.cnblog ...

  3. dos命令为java程序赋值_在DOS命令行状态下,如果源程序HelloWorld.java在当前目录下,那么编译该程序的命令是() (5.0分)_学小易找答案...

    [判断题]run方法是运行线程的主体,若run方法运行结束,线程就消亡了 [单选题]在Java 程序中,下面哪个是不合法的标识符() (5.0分) [其它]请提交实验二压缩包 [单选题]在DOS命令行 ...

  4. java version 和javac版本不一致_解决linux下javac -version和java -version版本显示不一致...

    [javascript] view plaincopy [root@localhost usr]# $JAVA_HOME/bin/java -version bash: /bin/java: 没有那个 ...

  5. QGIS编译(跨平台编译)之十六:Expat编译(Windows、Linux、MacOS环境下编译)

    目录 1.Expat介绍 2.Expat下载 3.Windows下编译 4.Linux下编译 5.MacOS下编译 1.Expat介绍 Expat是一个用C语言开发的.用来解析XML文档的开发库,它最 ...

  6. OSG第三方库编译之三十四:Expat编译(Windows、Linux、Macos环境下编译)

    目录 1.Expat介绍 2.Expat下载 3.Windows下编译 4.Linux下编译 5.MacOS下编译 1.Expat介绍 Expat是一个用C语言开发的.用来解析XML文档的开发库,它最 ...

  7. JAVA找门的第三天(Git配置,Editplus运行java程序)~~~

    1.远程控制电脑命令实现:win+R,打开运行命令框,输入mstsc(远程桌面连接),然后输入对方的IP地址 2.安装vscode过后,其插件的默认安装目录都为"C/User/<Use ...

  8. Java 7:在不丢失数据的情况下关闭NIO.2文件通道

    关闭异步文件通道可能非常困难. 如果您将I / O任务提交到异步通道,则需要确保正确执行了任务. 实际上,出于多种原因,这对于异步通道可能是一个棘手的要求. 默认的通道组使用守护进程线程作为工作线程, ...

  9. QGIS编译(跨平台编译)之四十四:HDF5编译(Windows、Linux、MacOS环境下编译)

    目录 1.hdf5介绍 2.hdf5下载 3.Windows下编译 4.Linux下编译 5.MacOS下编译 1.hdf5介绍 HDF5 (Hierarchical Data Format) 是一种 ...

最新文章

  1. 支付宝app支付总结
  2. vsftpd配置文件详解 ---配置解说
  3. django一对多、多对多模型、自关联的建立
  4. 2021算法竞赛入门班第七节课【图论】练习题
  5. 腾讯阿里字节扎堆做公益,互联网技术也要“内卷”?
  6. 18_使用react脚手架构建应用
  7. layui 如何去dom_常用元素操作 - layui.element
  8. deepfakes怎么用_[mcj]deepfakesApp使用说明(1)
  9. Windows 7 切换Python版本
  10. 【ElasticSearch】Es 源码之 Transport 和 TransportService 源码解读
  11. 怎么潜入别人家_小学生发明防雾口罩,别人家的孩子是怎么养成的?
  12. 基于依存句法规则的篇章级情感分析demo
  13. 探索python--Robert J. Brunner
  14. 语言模型(NNLM)
  15. python+django+mysql电影院选座订票系统毕业设计毕设开题报告
  16. Java读取证书报错:java.io.IOException: Unknown named curve: 1.2.156.10197.1.301
  17. 隔离模块介绍-隔离电源模块
  18. 【5G RRU专题】什么是PA非线性失真?
  19. it行业发展前景怎么样?互联网寒潮来袭是真的吗?
  20. chart metadata is missing these dependencies

热门文章

  1. vijos1197-费解的开关【递推,枚举,位运算】
  2. 【动态规划】最小代价问题
  3. 洛谷-P2801 教主的魔法 分块
  4. 2017西安交大ACM小学期 神器插座 KMP匹配
  5. 五分钟轻松了解Hbase面向列的存储
  6. 关于ByteBuffer使用解释
  7. 获取Spring的ApplicationContext的几种方式
  8. 从 Linux 源码看 Socket 的阻塞和非阻塞
  9. CommonResult响应工具类封装
  10. jQuery 操作元素