博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Andoird Crash的跟踪方法,使用腾讯Bugly来捕捉一些疑难杂症,让我们APP稳定上线...
阅读量:6706 次
发布时间:2019-06-25

本文共 3193 字,大约阅读时间需要 10 分钟。

Andoird Crash的跟踪方法,使用腾讯Bugly来捕捉一些疑难杂症,让我们APP稳定上线


我们在开发中常常会注意到一些Crash,这正是很头疼的,而且Crash会带来很多意想不到的状态,很恶心,所以今天,我们来着重研究一下Crash,同时,我们也将使用第三方SDK,也就是腾讯的Bugly来扑捉这些Crash,让他无所遁形。

一.糟糕的Android Crash

作为开发人员,很容易就能碰到Crash,但是作为用户,我相信也有很大部分人碰到过Crash,这些原因,也正是Android的平台差异化和适配所导致的,而且,你要是你安装一个软件就Crash,我想你会立马把他卸载掉。同时心理嘲笑了一下开发人员,有些用户还有可能会去商店给你差评之类的,这就不多说了,反正会直接影响到你APP的口碑和市场竞争能力,你要是一些用户很多的APP的话,你还得考虑用户留存和收入的问题了

而在以前,我们是怎么处理Crash的呢?一般有三个补救措施吧,感觉,当然,还有其他,待补充:

  • 1.等待用户反馈,这样很被动
  • 2.了解出错原因,让用户提供日志和使用场景,不靠谱,攒人品吧
  • 3.提示用户反馈,这样对用户体验有点糟糕

而在以前,很多厂商基本都这样搞过,归根究底,还是现在的APP质量,仍然不敢恭维

我今天讲的是腾讯的Bugly处理Crash的方式,主要还是因为他使用比较简单吧,初始化也就一行代码,而且可以监控和获取日志,挺不错的

二. Crash分类

一般Crash也是分了两类

  • Java Crash

java代码触发,Jvm虚拟机退出,系统弹框提醒用户,这个我们可以看log查看报错原因,Crash工具都能捕获到。

这里写图片描述

  • Native Crash

C/C++代码触发,Linux进程退出,无系统提示,这就需要一些第三方工具去捕获了

三.模拟Crash的产生

其实我们可以非常简单的实现一个java的Crash,比如空指针,很正常就能产生,我们这样来写MainActivity

public class MainActivity extends AppCompatActivity {
private Button button; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); button.setText("Android Crash"); }}

我都没给这个button初始化就赋值,肯定会报空指针异常,效果如上图,而在我们上图中是提到的,我们可以使用log去收集错误

这里写图片描述

我们可以看到他的错误是空指针,而错误在MainActivity的16行

这里写图片描述

这样我们的问题就一下子找到了

而如果集成了腾讯Bugly的话,他输出的日志就比较详细了,那具体是怎样的输出,我们现在就来集成一下把!

四.集成腾讯Bugly

要集成Bugly,肯定要去Bugly的官网

  • Bugly官网:

这里写图片描述

当然,Bugly的集成还是相对来说比较简单的,我们只要按照他的官方文档来

首先要做的,就是下载SDK了(如果你添加依赖的话,就不需要下载)

这里写图片描述

下载之后,我们可以看到他里面包含着四个文件

这里写图片描述

我们可以根据他们的接入指南来,因为我们是android studio开发,所以我把流程走一遍

在Module的build.gradle文件中添加依赖和属性配置:

dependencies {    compile 'com.tencent.bugly:crashreport:latest.release' //其中latest.release指代最新版本号,也可以指定明确的版本号,例如2.1.5}

这里要注意了,Bugly还提供了ndk动态库,我们如果要看C的日志可以使用

这里写图片描述

如果你集成了这些的话,你在Module的build.gradle文件中添加依赖和属性配置:

android {   defaultConfig {        ndk {            // 设置支持的SO库架构            abiFilters 'armeabi' //, 'x86', 'armeabi-v7a', 'x86_64', 'arm64-v8a'        }    }}dependencies {    compile 'com.tencent.bugly:crashreport:latest.release' //其中latest.release指代最新版本号,也可以指定明确的版本号,例如2.1.5    compile 'com.tencent.bugly:nativecrashreport:latest.release' //其中latest.release指代最新版本号,也可以指定明确的版本号,例如2.2.0}

可以参考官方提供的这张图

这里写图片描述

注意:自动集成时会自动包含Bugly SO库,建议在Module的build.gradle文件中使用NDK的“abiFilter”配置,设置支持的SO库架构。

如果在添加“abiFilter”之后Android Studio出现以下提示:

NDK integration is deprecated in the current plugin. Consider trying the new experimental plugin.

则在项目根目录的gradle.properties文件中添加:

android.useDeprecatedNdk=true

接着你就可以添加他所需要的一些权限了

好,现在我们需要去注册一个APP了,进入你的后阳台选择注册app

这里写图片描述

注册成功之后就可以看到全貌了,并且可以看到appid了,我们需要这个id

这里写图片描述

现在我们拿到了APPID:900033301,那我们可以去初始化了,建议是在Application中,所以我新建一个Application,并在清单文件,Application的根节点添加name属性

package com.lgl.androidcrash;import android.app.Application;import com.tencent.bugly.crashreport.CrashReport;/** * Application初始化 * Created by LGL on 2016/6/10. */public class CrashApplication extends Application {
//初始化 @Override public void onCreate() { super.onCreate(); //是否调试 CrashReport.initCrashReport(getApplicationContext(), "900033301", false); }}

到这里,Bugly的配置基本上是OK的,我们可以引起一个bug,然后日志过滤一下

这里写图片描述

便可以看到

这里写图片描述


这里写图片描述

当然,你也可以去Bugly的后台查看

这里写图片描述

我们可以查看详情

这里写图片描述

分析的很透彻,我们很容易就找到问题的所在了

关于腾讯Bugly还有很多妙用,推荐大家详细阅读他们的文档,本博客只是抛砖引玉来教大家如何的使用罢了,终究只是一些皮毛而已,谢谢各位看官赏脸。

我的群:555974449可以来讨论讨论!

你可能感兴趣的文章
解决delphi10.2.3 android tools闪退
查看>>
在ASP.NET Atlas中创建自定义的Action
查看>>
深度观察:腾讯收购大众点评背景下的O2O大格局
查看>>
Python 标准库 urllib2 的使用细节
查看>>
T-SQL with as 的用法(转)
查看>>
Android嵌入式系统程序开发
查看>>
LightOJ 1061 N Queen Again(记忆化搜索)
查看>>
互斥量和信号量的区别
查看>>
Csharp run sql script create database
查看>>
#pragma once 与 #ifndef 的区别解析
查看>>
How to check Ubuntu version
查看>>
JS对表格排序(支持对序号,数字,字母,日期)
查看>>
Vue2 第三天学习
查看>>
php 解析xml 的四种方法(转)
查看>>
qt 试用 (3)配置编译源代码及调试
查看>>
(转)用CSS3移除点击交互元素的高亮背景
查看>>
遍历json获得数据的几种方法
查看>>
php Collection类的设计
查看>>
c++中的计时器代码
查看>>
语义Web和本体开发相关技术
查看>>