2024年安卓最全一线大厂资深APP性能优化系列-卡顿定位(一),2024年最新阿里的面试题

最后

说一千道一万,不如自己去行动。要想在移动互联网的下半场是自己占有一席之地,那就得从现在开始,从今天开始,马上严格要求自己,既重视业务实现能力,也重视基础和原理。基础夯实好了,高楼才能够平地而起,稳如泰山。

最后为了帮助大家深刻理解Android相关知识点的原理以及面试相关知识,这里放上相关的我搜集整理的24套腾讯、字节跳动、阿里、百度2020-2021面试真题解析,我把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包知识脉络 + 诸多细节

还有 高级架构技术进阶脑图、Android开发面试专题资料 帮助大家学习提升进阶,也节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习。

一线互联网面试专题

379页的Android进阶知识大全

379页的Android进阶知识大全

网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

2.测量时间方式

首先,如果要查看页面加载花费的时间有3种方式

  1. adb命令查看
  2. 手动打点的方式
  3. traceView

3.adb命令

只需要一行命令,就可以查看加载页面的时间。

adb shell am start -W 包名/包名.Activity

使用后会显示

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. 信息全面,包含所有进程

5.2 使用方式

Debug.startMethodTracing(“文件名”);

Debug.stopMethodTracing();
复制代码

在代码中相应位置的地方打入埋点即可, startMethodTracing 有3个构造参数分别是

  1. tracePath:文件名/路径
  2. bufferSize:文件的容量大小
  3. flag:TRACE_COUNT_ALLOCS 只有默认的这一种

代码运行完成后,会在

mnt/sdcard/Android/data/包名/files

学习路线+知识梳理

花了很长时间,就为了整理这张详细的知识路线脑图。当然由于时间有限、能力也都有限,毕竟嵌入式全体系实在太庞大了,包括我那做嵌入式的同学,也不可能什么都懂,有些东西可能没覆盖到,不足之处,还希望小伙伴们一起交流补充,一起完善进步。

这次就分享到这里吧,下篇见

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值