android - Gradle 的目的是什么?

标签 android gradle android-studio android-gradle-plugin

我可以在 Android Studio 0.4.0 的上下文中帮助理解 Gradle(plugin v 0.7) 背后的概念。我以前没有使用过 Gradle,它给我带来的只是问题。我没有看到它的目的/好处,因为我对此了解不够。

我有一些具体问题

  1. 这些依赖项是什么?我正在制作一个简单的应用程序 抽屉导航,针对 API 11+,它应该是 native 的 支持的。我可以使用哪些依赖项?

  2. 什么是 Gradle 包装器?对完成的申请有什么改变(如果有的话)?

  3. 为什么 Gradle 需要经常在线?我没有 工作时在我的个人笔记本电脑上上网。得到了 以至于我无法运行或测试我的应用程序,因为 Gradle 不能 解决一些无法访问互联网的资源。

  4. 为什么 Gradle 使用 Groovy 很重要?我已经搜索过 在互联网上,这往往是人们喜欢的东西 Gradle,但他们通常不会解释为什么 Groovy 很重要或 它对 Android 应用有什么作用。

有时作为中级程序员很难,因为信​​息往往过于简单或过于复杂。除了我的具体问题之外,您可以提供的任何其他信息都会很有用。我不想争论 Gradle 与其他可能做同样事情的工具的优缺点,我只想更多地了解 Gradle 及其用途,以便做出明智的决定。

谢谢

最佳答案

您的一些问题很笼统,因为它们说明了为什么构建工具作为一般问题是一件好事。其他人专门使用 Gradle。我会尽量简洁地处理这两个类别,同时避免其他人挑剔的术语。

Maven、Gradle、SBT、Leiningen 等构建工具有助于自动执行我们原本必须手动执行或“手动自动执行”的任务。我使用后者来描述我过去使用 Ant 所做的事情——编写自定义任务来编译、运行、生成 Javadoc 等,以便将来可以自动化这些任务。通过遵守最初由 Maven 定义并随后被其他人采用的约定(例如将您的源代码放在 src/main/java 中),这成为可能。如果我遵循约定,构建工具可以编译、运行、生成 Javadoc、测试和其他所有工作,而只需最少的额外工作。

现在回答您的问题(按顺序):

  1. 构建工具的另一个关键功能是通过以一致的方式管理构建之间的依赖关系来减少“jar hell ”。我只是指定我想要的 Apache Commons 或 Google Guava 或 Spring 或 Jackson 的版本(甚至是版本范围),构建工具将下载它们并将它们放在某个地方,以便它们可以在类路径中,如果适用的话,在构建中(比如 war 文件)。我还可以定义范围——比如我希望这个依赖在编译时可用,而另一个依赖只在运行时可用。我需要明确提供它,还是可以使用它?诸如此类。
  2. 这是 Gradle 特有的。如所述here ,Gradle 包装器可帮助团队运行 Gradle,而无需手动安装 Gradle,同时还保持一致性。每个人都使用相同的版本。一旦你设置好它,你就不必担心它,你想使用的所有 Gradle 任务都可以通过包装器获得,所以你甚至不需要关心它在那里。可以选择直接安装Gradle,直接运行,但是我很少看重点。
  3. 这是一般情况。我之前提到了依赖管理。为了获取这些依赖项,构建工具需要从 Maven Central 或一堆第三方存储库中获取它们。其他人采用的另一个 Maven 创新是存储库管理,因此编译的 Artifact 按照约定发布到存储库,以便其他项目可以使用它们。通常,你并不关心这个。你只需告诉工具你需要某种依赖,它就知道如何获取它,因为每个人都遵循约定。在您无法访问 Internet 的情况下(我对此非常熟悉),您的选择是在您在线时获取所有依赖项,然后可以选择设置一个本地 Maven 存储库,如 Nexus 或 Artifactory 以将这些 Artifact 发布到。然后你告诉你的构建工具去那里看看 Maven Central 等等。
  4. Maven 是用 XML 配置的,这在当时看起来真的很酷。但是有两个后果。一是配置变得非常冗长。另一个是很难做定制的事情。您必须以声明方式在 XML 中做所有事情,许多人觉得这很痛苦。您可以在 XML 中配置插件,或者您自己编写并以 Maven 可以理解并可以在 XML 中配置的方式包装它。在代码中进行自定义构建要容易得多,功能也更强大。 Gradle 为此选择了 Groovy,因为 Groovy 可以提供很好的 DSL,并且对于来自 Maven 的 Java 开发人员来说非常容易学习。 SBT 选择了 Scala,而 Leiningen 选择了 Clojure,因为这些构建工具针对这些语言/平台,因此,例如,Scala 开发人员无需学习任何新知识即可使用 SBT,除了 DSL。但更广泛的一点是,依赖代码而不是 XML 有很多好处。

希望对您有所帮助。

关于android - Gradle 的目的是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20787986/

相关文章:

java - 如何从 keystore 导出 .key 和 .crt

java - 更改不在应用程序类中的书法默认字体

Gradle 中的 Scala REPL

android - 更改 AndroidManifest 中的版本代码不起作用

android - 为具有额外属性的 Gson 定义模型

Android - 在 RecyclerView 中重新创建自定义动态生成的复合 View ,导致性能不佳

java - 我可以从一个外部库导入和编辑代码吗? (例如谷歌地图实用程序)

android - 没有可调试的进程并将调试符号分配给 .so 文件

android - 是否可以在gradle productFlavors中声明变量并在Java中使用它?

android - .so 模块中定义的文件不会成为最终 APK 的一部分