APP性能优化系列-卡顿定位(一),对Android开发的现状和未来发展的思考

ThisTime: 代表启动最后一个Activity的耗时

TotalTime: 代表启动所有的Activity的耗时

WaitTime: 代表AMS启动所有的Activity的耗时

注意点:该命令只能是获取配置了的Activity, 其他的无效,因为Android组件中有个 exported 属性,没有intent-filter时exported 属性默认为false,此组件只能由本应用用户访问,配备了intent-filter后此值改变为true,允许外部调用。

缺点: adb命令只能查看配置了的Activity,其他的无法查看,并且也无法精准的查看其方法具体耗费的时间,所以因为其局限性 并不能很好的解决我们问题,我们采用手动打点的方式查看。

4.手动打点


先看代码

public class MyApplication extends Application {

@Override

public void onCreate() {

super.onCreate();

initBugly();

initBaiduMap();

initJPushInterface();

initShareSDK();

}

private void initBugly() throws InterruptedException {

Thread.sleep(1000); // 模拟耗费的时间

}

private void initBaiduMap() throws InterruptedException {

Thread.sleep(2000); // 模拟耗费的时间

}

private void initJPushInterface() throws InterruptedException {

Thread.sleep(3000); // 模拟耗费的时间

}

private void initShareSDK() throws InterruptedException {

Thread.sleep(500); // 模拟耗费的时间

}

}

代码不用我说,项目中很常见,现在的问题是APP启动加载很慢, 那么如何精准的查询到具体耗时的方法?

long startTime = System.currentTimeMillis();

initBugly();

Log.d(“lybj”, “initBugly()方法耗时:”+ (System.currentTimeMillis() - startTime));

long startTime = System.currentTimeMillis();

initBaiduMap();

Log.d(“lybj”, “initBaiduMap()方法耗时:”+ (System.currentTimeMillis() - startTime));

这样可以吗?当然不行,耦合性太大,每一个方法都加,那么测试完了,删除代码也是个体力活,一不小心删错一个,就会造成灾难性的问题,在实际项目中,比如中石油的一些项目,就会采用 AOP 的方式来测量方法的耗费时长。

4.1 AOP

AOP : Aspect Oriented Programming的缩写,意为:面向切面编程

优点:

  1. 针对同一问题的统一处理

  2. 无侵入添加代码

这里我们使用的是Aspectj

4.2 Aspectj 的使用

1.添加依赖

根目录的build.gradle里

buildscript {

dependencies {

classpath ‘com.hujiang.aspectjx:gradle-android-plugin-aspectjx:2.0.0’

}

}

app项目的build.gradle及新建的module的build.gradle里添加

apply plugin: ‘android-aspectjx’

dependencies {

implementation ‘org.aspectj:aspectjrt:1.8.+’

}

2.创建切面

@Aspect

public class PerformanceAop {

@Around(“call(* com.bj.performance.MyApplication.**(…))”)

public void getTime(ProceedingJoinPoint joinPoint){

long startTime = System.currentTimeMillis();

String methodName = joinPoint.getSignature().getName();

try {

joinPoint.proceed();

} catch (Throwable throwable) {

throwable.printStackTrace();

}

Log.d(“lybj”, methodName + “方法耗时:”+ (System.currentTimeMillis() - startTime));

}

}

复制代码

看,根本无需修改任何工程代码,就可以获取运行时长了,点击运行显示

AspectJ语法参考

缺点: 如果项目比较庞大,上百个方法,总不能全部打点,然后一个一个的分析到底是哪个地方运行时间过长吧,所以我们需要一个比较直观的工具,一眼就能看到具体哪个方法运行时间过长。

5. traceView的使用


5.1 特点

  1. 图形的形式展示其执行时间调用栈

  2. 信息全面,包含所有进程

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级安卓工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Android移动开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Android)
img

最后看一下《Android框架体系架构(高级UI+FrameWork源码)》学习需要的所有知识点的思维导图。在刚刚那份学习笔记里包含了下面知识点所有内容!文章里已经展示了部分!如果你正愁这块不知道如何学习或者想提升学习这块知识的学习效率,那么这份学习笔记绝对是你的秘密武器!

**
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Android)
[外链图片转存中…(img-8mUnRIwZ-1711381674440)]

最后看一下《Android框架体系架构(高级UI+FrameWork源码)》学习需要的所有知识点的思维导图。在刚刚那份学习笔记里包含了下面知识点所有内容!文章里已经展示了部分!如果你正愁这块不知道如何学习或者想提升学习这块知识的学习效率,那么这份学习笔记绝对是你的秘密武器!

[外链图片转存中…(img-uJw7bSyw-1711381674441)]

  • 21
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值