当前位置:K88软件开发文章中心编程语言APP编程Android01 → 文章内容

12.5 DrySister看妹子应用(第一版)——5.代码回顾,调整与日志类编写

减小字体 增大字体 作者:佚名  来源:网上搜集  发布时间:2019-1-12 6:28:22

1.一些BB说来惭愧,DrySister的上一篇距今已经有一年多了,期间有不少小伙伴都曾私信过我说写得很好,稳什么时候更,我基本都回复说太监了...具体原因各种各样吧,最近一段时间比较闲,就想把第一版的完结了吧。之前刚开始写的时候是AS 2.1.2,现在都AS 3.0.1了,本节的内容依次是:Step 1:温习一波之前几节涉及到的东西Step 2:代码在AS 3.0.1上跑要做一些调整Step 3:编写一个日志类下节我们来说说签名,混淆,以及发布到应用市场~废话不多说,开始本节内容!2.代码回顾第一节:项目搭建与简单实现1.Git相关的操作2.简单的图片加载类(获取网络流->转换成图片->Handler更新UI)第二节:解析后台数据1.使用Android自带抠脚Json解析器解析后台返回的Json数据(Json字符串 -> List<Bean>)2.使用AsyncTask来做异步网络请求第三节:图片加载优化(写个图片缓存小框架)1.图片缓存的基本套路2.使用采样压缩法压缩Bitmap,避免OOM3.线程池管理多个图片加载线程4.Handler更新UI5.String字符串(这里是URL)转MD56.内存缓存类LruCache的使用7.磁盘缓存类DiskLruCache的使用8.整个图片异步加载缓存的逻辑设计第四节:添加数据缓存(加入SQLite)1.网络状态的判断2.自定义SQLiteOpenHelper创建数据库3.数据库相关操作:增删改查,事务,分页等以上就是前面四节的内容,对于Android基础入门中重要的知识点都进行了运用,如果都掌握了的话,算是勉强Android入门了,后面的路还长着呢!3.代码调整AS切换到3.0以后,下述文件的代码需要进行改动,老规矩,切换分支命令走一波:git checkout -b fixcodeas3.0.1,然后开始代码修改:项目层级的build.gradle:APP层级的build.gradle:gradle-wrapper.properties:还有个地方要小改:SisterApi.java,把福利改成:%e7%a6%8f%e5%88%a9这涉及到了中文转码问题,而HttpUrlConnection无法打开含有中文的链接,需要对中文部分调用URLEncoder.encode(中文部分,"utf-8");进行转码,记得只是中文部分,不是整个url!!!转码还需要捕获异常,这里因为只有一个地方要转码,我就直接用网页版的转码工具来转码了:https://c.k88.net/front-end/695转换后的结果:另外还有一些小改,buildToolsVersion 26以上,findViewById是不用强转的,点进去方法看就知道了,用了泛型,所以把findViewById都去掉:最后觉得运行再我的魅蓝E2上效果有点偏差,小调了一下页面布局,让图片宽度满屏然后高度自适应,这里用到的属性 android:adjustViewBounds = "true",就是宽高按比例缩放;还有把上一步下一步的文字放到strings.xml文件中,小调边距:最后再来看我们的项目运行结果:(啧啧,好看的妹子就是养眼):然后把这个分支合并到develop分支上,这里我们不用之前merge那种合并套路而是用rebase来合并,具体过程如下:git add .git commit -m "fix code in as3.0"git checkout develop # 切换到develop分支git rebase fix_code_as3.0.1 # 合并分支git push origin develop # 推送develop到远程分支git branch -d fix_code_as3.0.1 # 删除合并后的本地分支关于Git还不懂的可以去另一篇文章学习,这里就不多解释了:小猪的Git使用总结4.编写日志工具类与崩溃日志采集类Log打印日志相信每一位开发者都不会陌生吧,平时调试必不可少,当应用打包给测试测试时。测试反馈应用crash的时候,我们第一件想到的事就是让对方提供日志。说到这个打Log,很多童鞋喜欢随手一个Log.e(xxx,xxx),什么日志都是Error级别,原因基本是:红色比较醒目,哈哈!然后直接把变量的值打印处理啊,或在某个方法里加上,验证方法是否执行了等,正式发布的收记得删还好,不记得删的话简直是作死。反正之前给上家公司的大佬喷了一顿,至今记忆犹新!Log的管理非常重要,我们要写的两个工具类如下:1.debug的时候日志正常打印,release的时候不打印2.奔溃日志采集,自己测试或者测试测试倒没什么,崩溃了直接把手机接你电脑上看看logcat就一清二楚了,但是如果应用装到了用户手机里,应用崩溃停止运行了,用户可不会把日志发给你,多次崩溃还可能导致用户卸载你的APP,所以我们需要在APP崩溃的时候把日志保存起来,当用户连接wifi或再次打开应用时,把这个日志上传到我们的服务器,我们这里只是写来玩玩的,所以只做本地崩溃日志采集,一般都是通过集成第三方的统计工具来进行日志采集的,比如友盟,Bugly等。好的,需求就上面的两点,接着准备开始编写代码,不过在写代码之前科普关于Log的两点,可能大部分的童鞋都已经知道了,知道的可以直接跳过:1) 快速打印Log打开设置,依次点击:Live Templates -> AndroidLog把日志打印的都勾上你还可以自己在下面的Template text里编写模板~接着随便代码里键入上面的log...一个enter,Log语句就出来了,TAG直接就是你当前的方法名~2.关于Log的使用科普1) 快速打印Log打印命令打开Settings,依次点击:Live Templates -> AndroidLog把日志打印的都勾上你也可以自己在下面的Template text里编写模板~接着随便代码里键入上面的log...一个enter,Log语句就出来了~如果你在方法外,键入logt,可以直接生成一个对应类名的TAG:2) Log等级的科普以前组长开小会的时候曾说过我们调试时直接Log.e的坏习惯,不同的Log级别应该打印不同的信息:Log.v:Verbose(冗长)开发调试过程中一些详细信息,不该编译进产品,只在开发阶段使用Log.d:Debug(调试)用于调试的信息,编译进产品,运行时关闭。下面这三种等级进制作为普通调试信息使用,这些等级的Log是应用出现问题时候的重要分析线索,如果随意使用,会给开发人员分析Bug带来不必要的困扰。Log.i:Info(信息)例如一些运行时的状态信息,这些状态信息在出现问题的时候能提供帮助。Log.w:Warning(警告)警告应用出现了异常,但不一定会马上出现错误,需要留意Log.e:Error(错误)应用出现了错误,最需要关注解决的!3) 编写日志工具类老规矩,先开辟分支:buglogcatch这个就非常简单了,调试时输出,正式版时不输出,利用BuildConfig.Debug进行判断即可,代码如下:4) 编写崩溃日志采集类崩溃日志采集类依赖于Application与Thread.UncaughtExceptionHandler实现~当因为程序因为未捕获的异常即将终止退出时,会使用Thread.UncaughtExcept

[1] [2]  下一页


12.5 DrySister看妹子应用(第一版)——5.代码回顾,调整与日志类编写