AndroidStudio 使用Gradle 控制Log 日志输出
2016-09-27 15:20
501 查看
我们在开发APP的时候,在测试的时候需要打Debug 包,在正式发布的时候打 Release 包;但是在正式发布的时候我们需要把在研发阶段的Log日志打印给取消掉,设置用户不可见,研发可见。过多的打印Log日志也是会影响APP的性能的,所以我们就以此做区分!
1、常规的操作我们是创建Log管理类来管理Log日志打印
2、通过 配置gradle
第一种方法就不在演示了。在这里只做下第二种效果的设置,在此之前简单的了解下buildConfigField 属性
编译Gradle 在 BuildConfig 类中自动生成 常量字段与常量值。为此我们可以使用该方法进行常量的储存,如appkey,等等!
打开 项目所在gradle 配置下相关属性,使用Gradle 的自定义BuildConfig字段 设置如下:
编译Gradle 查看 BuildConfig.java 增加了相关字段
测试用例:
打印结果:
Release 的就不在上传了!空白的控制台!
这样我们在打包的时候 就可以直接直接打包,而无需在配置一些常量 true/false 字段以区分 Debug或者 Release 包了!
由此可见Gradle的强大!······
1、常规的操作我们是创建Log管理类来管理Log日志打印
2、通过 配置gradle
buildConfigField("boolean", "enableLog", "false")来进行管理
第一种方法就不在演示了。在这里只做下第二种效果的设置,在此之前简单的了解下buildConfigField 属性
/** *@param type 类型 *@param name 指定的常量字段 *@param value 常量字段值(如果是字符串的话,这时候就需要对其字符串进行转义了"/" 进行转义处理即可) */ buildConfigField(String type,String name,String value);
编译Gradle 在 BuildConfig 类中自动生成 常量字段与常量值。为此我们可以使用该方法进行常量的储存,如appkey,等等!
打开 项目所在gradle 配置下相关属性,使用Gradle 的自定义BuildConfig字段 设置如下:
apply plugin: 'com.android.application' android { compileSdkVersion 24 buildToolsVersion "24.0.0" defaultConfig { applicationId "com.wangly.java" minSdkVersion 19 targetSdkVersion 24 versionCode 1 versionName "1.0" // 控制日志Log 输出打印 buildConfigField("boolean", "enableLog", "true") } buildTypes { release { // 控制日志Log 输出打印 buildConfigField("boolean", "enableLog", "false") minifyEnabled false proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' } } } dependencies { compile fileTree(dir: 'libs', include: ['*.jar']) testCompile 'junit:junit:4.12' compile 'com.android.support:appcompat-v7:24.0.0-beta1' }
编译Gradle 查看 BuildConfig.java 增加了相关字段
public final class BuildConfig { public static final boolean DEBUG = Boolean.parseBoolean("true"); public static final String APPLICATION_ID = "com.wangly.java"; public static final String BUILD_TYPE = "debug"; public static final String FLAVOR = ""; public static final int VERSION_CODE = 1; public static final String VERSION_NAME = "1.0"; // Fields from default config. public static final boolean enableLog= true; //控制Log日志的打印 }
测试用例:
public void outLogClick(View view) { Log.d("wangly", "得到的 Boolean 类型值:" + BuildConfig.enableLog); if (BuildConfig.enableLog) { // 获取配置的字段 LogHelper.e("wangly", "--------"); } LogHelper.e("wangly","--------"); } }
打印结果:
Release 的就不在上传了!空白的控制台!
这样我们在打包的时候 就可以直接直接打包,而无需在配置一些常量 true/false 字段以区分 Debug或者 Release 包了!
由此可见Gradle的强大!······
相关文章推荐
- android使用log输出日志注意
- robotium测试工具使用之——输出log日志
- iOS开发的一些小技术:让UIImage有缩放功能、控制log的输出、xcode修改文件注释、随机数的使用、在UIImageView 中旋转图像、在Quartz中如何设置旋转点、创建.plist文件并存储
- ROSETTA使用技巧随笔--控制Log输出等级
- android开发,使用log在native code中输出日志
- robotium测试工具使用之——输出log日志
- [置顶] 使用logback随意控制spring源码相关包的日志输出
- 使用Xcode开发phoneGap应用时使用console.log()输出日志。
- 用C++使用Android Log API输出日志
- 使用最新的log4cplus(1.1.1)输出多个自定义日志文件,隔离不同的 log 文件输出
- 使用p6spy新版监控分析sql输出log日志
- 发布应用时控制log日志输出
- Android——使用StackTraceElement实现自己的Log日志输出管理类
- 使用log4j进行日志控制输出
- robotium测试工具使用之——输出log日志
- 在程序中输出日志, 使用 android.util.Log 类.
- 【Log】一个功能强大的Log封装库包括控制日志输出,保存Log到文件,过滤输出等级。。
- 经常使用Log日志打印输出
- perl 使用Log::Log4perl输出日志
- 使用ApexSQL Log来查看sql server的日志文件