2024年安卓最全Android应用测速组件实现原理,这篇看完还不懂跟我去摆地摊!,快手面试经验java

写在最后

对程序员来说,很多技术的学习都是“防御性”的。也就是说,我们是在为未来学习。我们学习新技术的目的,或是为了在新项目中应用,或仅仅是为了将来的面试。但不管怎样,一定不能“止步不前”,不能荒废掉。

![
[]


文章以下内容会给出阿里与美团的面试题(答案+解析)、面试题库、Java核心知识点梳理等

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

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

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

页面渲染耗时统计

什么时候才算页面渲染完成呢?

Rabbit定义ActivityContentView绘制完成就是页面渲染完成,我们可以通过监听ViewGroup.dispatchDraw()来监听Activity.ContentView绘制完成。

具体实现思路是: 手动为Activity.setContentView()设置的View添加一层自定义父View,用于计算绘制完成的时间

public class ActivitySpeedMonitor extends FrameLayout {

@Override
protected void dispatchDraw(Canvas canvas) {
super.dispatchDraw(canvas);
RabbitTracerEventNotifier.eventNotifier.activityDrawFinish(getContext(), System.currentTimeMillis());
}

public static void wrapperViewOnActivityCreateEnd(Activity activity) {
FrameLayout contentView = activity.findViewById(android.R.id.content);
ViewGroup contentViewParent = (ViewGroup) contentView.getParent();

if (contentView != null && contentViewParent != null) {
ActivitySpeedMonitor newParent = new ActivitySpeedMonitor(contentView.getContext());
if (contentView.getLayoutParams() != null) {
newParent.setLayoutParams(contentView.getLayoutParams());
}
contentViewParent.removeView(contentView);
newParent.addView(contentView);
contentViewParent.addView(newParent);
}
}
}

上面ActivitySpeedMonitor.wrapperViewOnActivityCreateEnd()代码会在编译时插入在Activity.onCreate方法中:

public class TransformTestActivity extends AppCompatActivity {

protected void onCreate(Bundle savedInstanceState) {
ActivitySpeedMonitor.activityCreateStart(this);
super.onCreate(savedInstanceState);
this.setContentView(2131296286);
ActivitySpeedMonitor.wrapperViewOnActivityCreateEnd(this);
}

}

Activity首次inflate耗时统计

我们知道ViewGroup.dispatchDraw()方法在ViewTree发生改变时就会调用,而一般第一次会导致dispatchDraw()被调用代码是:

setContentView(R.layout.activity_transform_test);

因此RabbitActivity的第一dispatchDraw()方法完成时间当做Activity首次Inflate结束时间点。

其实这个时间的长短可以代表Activity的布局复杂度。

Activity首次渲染耗时

这个耗时统计的时间结束点为: 页面发起网络请求拿到数据,并完成页面渲染

举个例子,比如你的应用首页有3个接口,这3个接口的数据组成了整个首页的UI, 首页的渲染耗时就是3个接口完成请求,并且数据渲染完成

Rabbit中对页面的渲染耗时统计需要配置,即配置一个页面哪些接口完成才算页面渲染完成, 具体配置约定为assest文件夹下提供rabbit_speed_monitor.json文件:

{
“home_activity”: “MainActivity”,
“page_list”: [
{
“page”: “MainActivity”,
“api”: [
“xxx/api/getHomePageRecPosts”,
“xxx/api/getAvailablePreRegistrations”,
“xxxx/api/appHome”
]
}

]
}

home_activity配置统计应用冷启动耗时。

page_list配置需要统计渲染耗时的页面。

Rabbit会在指定的所有接口都完成并且ViewGroup.dispatchDraw()方法完成时记录下这个时间点来作为渲染耗时:

RabbitAppSpeedMonitor.java

fun activityDrawFinish(activity: Any, drawFinishTime: Long) {
val apiStatus = pageApiStatusInfo[currentPageName]
if (apiStatus != null) {
if (apiStatus.allApiRequestFinish()) { //所有请求已经完成
pageSpeedCanRecord = false //只统计一次
pageSpeedInfo.fullDrawFinishTime = drawFinishTime
RabbitDbStorageManager.save(pageSpeedInfo)
}
}
}

如何统计接口完成呢?

网络请求耗时监控

也是利用RabbitAppSpeedInterceptor,不过这里监控的网络耗时时间并不是我们真正理解的网络请求耗时,时间大概介于 : 网络请求耗时 ~ 应用网络处理耗时,具体实现核心代码如下:

class RabbitAppSpeedInterceptor : Interceptor {

override fun intercept(chain: Interceptor.Chain): Response {

val startTime = System.currentTimeMillis()
val request = chain.request()
val requestUrl = request.url().url().toString()
val response = chain.proceed(request)

if (!RabbitTracer.monitorRequest(requestUrl)) return response // 不需要监控这个请求

val costTime = System.currentTimeMillis() - startTime

RabbitTracer.markRequestFinish(requestUrl, costTime)

return response
}
}

App冷启动耗时统计

结合上面的叙述,Rabbit定义App冷启动耗时HomeActivity渲染完成时 - Application.attachBaseContext()开始时

对于HomeActivity可以通过rabbit_speed_monitor.json进行配置:

【延伸Android必备知识点】

【Android部分高级架构视频学习资源】

**Android精讲视频学习后更加是如虎添翼!**进军BATJ大厂等(备战)!现在都说互联网寒冬,其实无非就是你上错了车,且穿的少(技能),要是你上对车,自身技术能力够强,公司换掉的代价大,怎么可能会被裁掉,都是淘汰末端的业务Curd而已!现如今市场上初级程序员泛滥,这套教程针对Android开发工程师1-6年的人员、正处于瓶颈期,想要年后突破自己涨薪的,进阶Android中高级、架构师对你更是如鱼得水!

**任何市场都是优胜略汰适者生存,只要你技术过硬,到哪里都不存在饱和不饱和的问题,所以重要的还是提升自己。懂得多是自己的加分项 而不是必须项。门槛高了只能证明这个市场在不断成熟化!**另外一千个读者就有一千个哈姆雷特,所以以上只是自己的关键,不喜勿喷!

如果你是卡在缺少学习资源的瓶颈上,那么刚刚好我能帮到你。欢迎关注会持续更新和分享的。

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

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

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

入研究,那么很难做到真正的技术提升。**

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

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

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android系统提供了一套API来帮助开发者实现Wifi测速功能。如下是一个使用Java语言实现的Android Wifi测速的示例: 首先,我们需要获取设备当前连接的Wifi信息。可以使用WifiManager类获取Wifi的相关信息,包括连接的Wifi网络的SSID、信号强度等。可以通过以下代码实现: ``` WifiManager wifiManager = (WifiManager) getSystemService(Context.WIFI_SERVICE); WifiInfo wifiInfo = wifiManager.getConnectionInfo(); String ssid = wifiInfo.getSSID(); int signalStrength = wifiInfo.getRssi(); ``` 接下来,我们需要实现测速的逻辑。可以通过开启一个后台线程,并使用Socket进行上传和下载测试。首先,我们需要创建一个Socket对象,用来进行网络连接: ``` Socket socket = new Socket(); socket.connect(new InetSocketAddress("www.example.com", 80), 5000); // 这里以连接www.example.com的80端口为例 ``` 然后,我们可以在Socket连接建立后,通过输入输出流进行上传和下载测试。具体实现如下: ``` OutputStream outputStream = socket.getOutputStream(); InputStream inputStream = socket.getInputStream(); // 上传测试 byte[] data = new byte[1024]; long startTime = System.currentTimeMillis(); for (int i = 0; i < 1000; i++) { outputStream.write(data); outputStream.flush(); } long endTime = System.currentTimeMillis(); long uploadTime = endTime - startTime; double uploadSpeed = 1000.0 * data.length / uploadTime; // 计算上传速度,单位为KB/s // 下载测试 startTime = System.currentTimeMillis(); byte[] buffer = new byte[1024]; int bytesRead; while ((bytesRead = inputStream.read(buffer)) != -1) { // do something with the downloaded data } endTime = System.currentTimeMillis(); long downloadTime = endTime - startTime; double downloadSpeed = 1000.0 * buffer.length / downloadTime; // 计算下载速度,单位为KB/s ``` 最后,我们需要释放资源并关闭连接: ``` outputStream.close(); inputStream.close(); socket.close(); ``` 通过上述方法,我们可以实现对当前连接的Wifi网络进行测速功能。根据实际需求,可以进行多次测速并计算平均速度,以提供更准确的测速结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值