|
在Choreographer内部有系统自带的卡帧警告,在Choreographer内部的doFrame()方法中,当这一帧与上一帧的间隔大于SKIPPED_FRAME_WARNING_LIMIT时会在info里打出log。
SKIPPED_FRAME_WARNING_LIMIT是Choreographer内部的静态变量,从SystemProperties中取出,如果没有的话默认值是30,我在模拟器Pixel xl中检测也是30。
但是注意,这是这一帧与上一帧的间隔,如果在主线程中连续出现几个小于30帧的卡顿,视觉上也会比较卡,毕竟1s60帧的话,20帧卡顿已经有333ms了,当连续出现两个基本上1s内都在卡顿。
从测试的结果来看基本上都在刚打开页面上出现,毕竟网络请求处理数据什么的以及刚开始的ui绘制是比较耗时的,而从Choreographer的代码来看是没有首帧判断的,这一点不如Android7.0 之后 的Window.FrameMetricsListener,但这是系统自带的,不需要任何的代码实现。
----------------------------
原文链接:https://blog.csdn.net/aliucheng729/article/details/104343782
程序猿的技术大观园:www.javathinker.net
[这个贴子最后由 flybird 在 2020-03-09 10:14:01 重新编辑]
|
网站系统异常
系统异常信息 |
Request URL:
http://www.javathinker.net/WEB-INF/lybbs/jsp/topic.jsp?postID=2614
java.lang.NullPointerException
如果你不知道错误发生的原因,请把上面完整的信息提交给本站管理人员。
|
|