Android中applicationId的定义

[原文地址](http://tools.android.com/tech-docs/new-build-system/applicationid-vs-packagename)
title="Url重定向器修改" width="100%" height="50" scrolling="no" id="1977211423" class="igm" src="//pd6vrh77l2o5770tln703abh1n14n9bt-a-sites-opensocial.googleusercontent.com/gadgets/ifr?url=http://hosting.gmodules.com/ig/gadgets/file/101516774607192005424/web-redirector.xml&container=enterprise&view=default&lang=en&country=ALL&sanitize=0&v=743553cb39d389ec&libs=core&mid=31&parent=http://tools.android.com/tech-docs/new-build-system/applicationid-vs-packagename#up_pageurl=https://developer.android.com/studio/build/application-id.html&up_timeout=4&st=e%3DAIHE3cBNMrnauAnNKOp2IFerXee1IH3%252BoRVGguA2pwzONPeFGn%252BTSCvwEeO0NZ5yR3mgzJ349IGnHC1DIlzSLCHQUEIoEpHv9HaTPIN7QYGWIJ7KSC6i073%252FayQa6DKAsMKAlJ1S0feF%26c%3Denterprise&rpctoken=-2945261956963500105">









所有Android应用程序都有一个包名称。包名称唯一标识设备上的应用程序; 它在Google Play商店中也是独一无二的。这意味着,一旦你发布了一个包名称的应用程序, 你永远不能改变它 ; 这样做会导致您的应用程序被视为一个全新的应用程序,现有的应用程序用户将不会看到新打包的应用程序作为更新。

在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 。

使用新的Android Gradle构建系统,您可以轻松构建 应用程序的多个不同 版本 ; 例如,您可以同时构建应用程序的“免费”版本和“专业版”(使用风格),并且这些应用程序在Google Play商店中应该有不同的软件包,以便它们可以分别安装和购买,同时,等等。同样,您也可以构建应用程序的“调试”和“alpha”和“beta”版本(使用构建类型),这些也可以类似地贡献于唯一的包名称。

同时,您在代码中导入的R类必须始终保持不变; 在构建不同版本的应用程序时,不应更改.java源文件。

因此,我们已经 解耦  了包名的两种用法:
  • 您构建的.apk清单中使用的最终包是应用程序在您的设备和Google Play商店中已知的包,即“应用程序ID”。
  • 在您的源代码中用于引用您的R类并解决任何相关活动/服务注册的包仍然称为“包”。
您可以在您的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"
        }
    }
    ....

(在Android Studio中,您也可以在“项目结构”对话框中以图形方式配置所有这些。)

注意:出于兼容性的原因,如果您 尚未  在build.gradle文件中定义applicationId,那么applicationId将默认为与AndroidManifest.xml中指定的值相同的值。在这种情况下,两者显然不是分离的,试图重构你的代码可能会意外地改变你的应用程序的ID!在Android Studio中,新创建的项目总是指定两者。

注2:软件包名称必须始终在默认的AndroidManifest.xml文件中指定。如果您有多个清单(例如特定于风味的清单或特定于buildType的清单),那么包名是可选的,但是如果指定了它,它必须与主清单中指定的包相同。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值