[原文地址](http://tools.android.com/tech-docs/new-build-system/applicationid-vs-packagename)
在Android Gradle构建系统之前,您的应用的软件包名称由清单文件根元素的软件包属性确定:
AndroidManifest.xml中:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.my.app"
android:versionCode="1"
android:versionName="1.0" >
然而,这里定义的包还有一个次要目的:它用来为你的R资源类命名包(以及将任何相关的类名解析为活动)。在上面的例子中,生成的R类将是
com.example.my.app.R
,所以如果你在其他包需要引用资源的代码,它需要导入
com.example.my.app.R
。
同时,您在代码中导入的R类必须始终保持不变; 在构建不同版本的应用程序时,不应更改.java源文件。
因此,我们已经
解耦
了包名的两种用法:
您可以在您的gradle文件中指定应用程序ID,如下所示:
应用程序/的build.gradle:
apply plugin: 'com.android.application'
android {
compileSdkVersion 19
buildToolsVersion "19.1"
defaultConfig {
applicationId "com.example.my.app"
minSdkVersion 15
targetSdkVersion 19
versionCode 1
versionName "1.0"
}
...
和以前一样,您需要在Manifest文件中指定用于代码的包,就像上面的AndroidManifest.xml示例中所示。
关键部分是这样的:
当你完成上述工作时,这两个包是独立的。您可以完全自由地重构代码 - 更改用于您的活动和服务的内部软件包,更新您的Manifest软件包并重构您的导入语句。这对您的应用程序的最终id没有任何影响,现在它总是在Gradle文件中指定的applicationId。
您可以通过使用以下Gradle DSL方法来改变应用程序的applicationId风格和构建类型:
应用程序/的build.gradle:
productFlavors {
pro {
applicationId = "com.example.my.pkg.pro"
}
free {
applicationId = "
com.example.my.pkg .free"
}
}
buildTypes {
debug {
applicationIdSuffix ".debug"
}
}
....
注意:出于兼容性的原因,如果您
尚未
在build.gradle文件中定义applicationId,那么applicationId将默认为与AndroidManifest.xml中指定的值相同的值。在这种情况下,两者显然不是分离的,试图重构你的代码可能会意外地改变你的应用程序的ID!在Android Studio中,新创建的项目总是指定两者。
注2:软件包名称必须始终在默认的AndroidManifest.xml文件中指定。如果您有多个清单(例如特定于风味的清单或特定于buildType的清单),那么包名是可选的,但是如果指定了它,它必须与主清单中指定的包相同。
|