记一发类型强转的bug

01 背景

最近在对视频落地页做一期简单重构,主要是把holder拆分成多个block,视频落地页有很多引导view是通过setLayoutParams的方式add进来的,这就为拆分埋下了一些隐患。

02 问题描述

铛铛铛,拆分完成,哈哈哈,滑动几下,好像也没啥问题奥。开心。挺有成就感,等等,怎么突然崩了。拆分完之后,心情大概就是上面这样的。QA也多次反馈出现了这个问题。下面是异常日志:

java.lang.ClassCastException: android.widget.FrameLayout$LayoutParams cannot be cast to android.widget.LinearLayout$LayoutParams
	at android.widget.LinearLayout.measureHorizontal(LinearLayout.java:1071)
	at android.widget.LinearLayout.onMeasure(LinearLayout.java:642)
	at android.view.View.measure(View.java:19967)
	at android.widget.RelativeLayout.measureChild(RelativeLayout.java:676)
	at android.widget.RelativeLayout.onMeasure(RelativeLayout.java:479)
	at android.view.View.measure(View.java:19967)
	at android.widget.RelativeLayout.measureChildHorizontal(RelativeLayout.java:715)
	at android.widget.RelativeLayout.onMeasure(RelativeLayout.java:461)
	at android.view.View.measure(View.java:19967)
	at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:6132)
	at android.widget.FrameLayout.onMeasure(FrameLayout.java:185)
	at android.view.View.measure(View.java:19967)
	at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:6132)
	at android.widget.FrameLayout.onMeasure(FrameLayout.java:185)
	at android.view.View.measure(View.java:19967)
	at com.baidu.minivideo.widget.VerticalViewPager.onMeasure(VerticalViewPager.java:1453)
	at android.view.View.measure(View.java:19967)
	at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:6132)
	at android.widget.FrameLayout.onMeasure(FrameLayout.java:185)
	at android.view.View.measure(View.java:19967)
	at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:6132)
	at android.widget.FrameLayout.onMeasure(FrameLayout.java:185)
	at android.support.v7.widget.ContentFrameLayout.onMeasure(ContentFrameLayout.java:141)
	at android.view.View.measure(View.java:19967)
	at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:6132)
	at android.widget.LinearLayout.measureChildBeforeLayout(LinearLayout.java:1464)
	at android.widget.LinearLayout.measureVertical(LinearLayout.java:758)
	at android.widget.LinearLayout.onMeasure(LinearLayout.java:640)
	at android.view.View.measure(View.java:19967)
	at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:6132)
	at android.widget.FrameLayout.onMeasure(FrameLayout.java:185)
	at android.view.View.measure(View.java:19967)
	at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:6132)
	at android.widget.LinearLayout.measureChildBeforeLayout(LinearLayout.java:1464)
	at android.widget.LinearLayout.measureVertical(LinearLayout.java:758)
	at android.widget.LinearLayout.onMeasure(LinearLayout.java:640)
	at android.view.View.measure(View.java:19967)
	at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:6132)
	at android.widget.FrameLayout.onMeasure(FrameLayout.java:185)
	at com.android.internal.policy.DecorView.onMeasure(DecorView.java:856)
	at android.view.View.measure(View.java:19967)
	at android.view.ViewRootImpl.performMeasure(ViewRootImpl.java:2642)
	at android.view.ViewRootImpl.measureHierarchy(ViewRootImpl.java:1717)
	at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1981)
	at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1593)
	at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:7089)
	at android.view.Choreographer$CallbackRecord.run(Choreographer.java:883)
	at android.view.Choreographer.doCallbacks(Choreographer.java:689)
	at android.view.Choreographer.doFrame(Choreographer.java:624)
	at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:869)
	at android.os.Handler.handleCallback(Handler.java:751)
	at android.os.Handler.dispatchMessage(Handler.java:95)
	at android.os.Looper.loop(Looper.java:159)
	at android.app.ActivityThread.main(ActivityThread.java:6385)
	at java.lang.reflect.Method.invoke(Native Method)
	at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1096)
	at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:883)

03 解决过程

日志信息很明显,本应该用LinearLayout.LayoutParams,但是现在使用的是FrameLayout.LayoutParams,但是查找的路径就比较坑了,因为addview的地方不少。
开始,我们经过路径分析,通过全局查找FrameLayout.LayoutParams,终于发现了一个可疑点,修复之后,我们信心满满的告诉QA,修好了,结果,QA反馈,早晨又崩了,WTF。
然后,我们继续排查,最终在一个陈年view里找到了,我们最开始都忽略了,那个view是同事很早之前封装的,我们都没注意,没成想,这次封装block,这个view的父布局变了,然后就出现了这个问题。

04 如何避免

1.重构的时候要把疑问点记录下来,多自测一下
2.注意调整布局的时候,封装block的时候,特别当心这种在代码里设置布局属性的情况,跟xml不一样,这个比较难排查。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值