Attempt to read from field 'int android.view.View.mViewFlags' on a null object reference

本文介绍了一种在Android TV应用中使用RecyclerView时遇到的NullPointerException异常现象及其解决方案。通过对比不同的getChildDrawingOrder方法实现,最终采用Android Leanback库中的实现方式解决了问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题描述

在tv开发中使用了RecyclerView做grid列表显示,但更新数据时却出现以下异常:

java.lang.NullPointerException
Attempt to read from field 'int android.view.View.mViewFlags' on a null object reference
android.view.ViewGroup.dispatchDraw(ViewGroup.java:3197)
android.view.View.updateDisplayListIfDirty(View.java:14162)
android.view.View.getDisplayList(View.java:14189)
android.view.View.draw(View.java:14959)
android.view.ViewGroup.drawChild(ViewGroup.java:3405)
android.view.ViewGroup.dispatchDraw(ViewGroup.java:3198)

如何解决

我在代码中用到了http://www.oschina.net/p/Android-Tv-Widget ,里面对RecyclerView做了封装,重写getChildDrawingOrder方法来实现“当前焦点视图放大但不会被旁边的视图遮挡”。就是这个重写导致了上面的错误,但是不知道具体原因。错误代码如下:

if (position != -1) {
            if (i == childCount - 1)
                return position;
            if (i == position)
                return childCount - 1;
        }
        return i;

后来我在Android v17包leanback中找到里面也有重写这个方法,将其代码copy过来,错误没有了。代码如下:

if (i < position) {
    return i;
} else if (i < childCount - 1) {
    return position + childCount - 1 - i;
} else {
    return position;
}

在此做一个记录,有同样的问题的,可以试下这样修改。有谁知道为啥会有这个问题,也请赐教。

分析报错 行 113554: 07-23 15:06:33.078 3765 13230 W System.err :13230): java.lang.NullPointerException: Attempt to read from field 'int androidx.constraintlayout.core.SolverVariable.id' on a null object reference 行 113555: 07-23 15:06:33.078 3765 13230 W System.err :13230): at androidx.constraintlayout.core.ArrayLinkedVariables.get(ArrayLinkedVariables.java:596) 行 113556: 07-23 15:06:33.079 3765 13230 W System.err :13230): at androidx.constraintlayout.core.ArrayLinkedVariables.use(ArrayLinkedVariables.java:349) 行 113557: 07-23 15:06:33.079 3765 13230 W System.err :13230): at androidx.constraintlayout.core.ArrayRow.updateFromRow(ArrayRow.java:561) 行 113558: 07-23 15:06:33.079 3765 13230 W System.err :13230): at androidx.constraintlayout.core.ArrayRow.updateFromSystem(ArrayRow.java:734) 行 113560: 07-23 15:06:33.086 3765 13230 W System.err :13230): at androidx.constraintlayout.core.LinearSystem.addConstraint(LinearSystem.java:573) 行 113561: 07-23 15:06:33.086 3765 13230 W System.err :13230): at androidx.constraintlayout.core.LinearSystem.addEquality(LinearSystem.java:1367) 行 113562: 07-23 15:06:33.087 3765 13230 W System.err :13230): at androidx.constraintlayout.core.widgets.ConstraintWidget.applyConstraints(ConstraintWidget.java:3263) 行 113563: 07-23 15:06:33.087 3765 13230 W System.err :13230): at androidx.constraintlayout.core.widgets.ConstraintWidget.addToSolver(ConstraintWidget.java:2714) 行 113564: 07-23 15:06:33.087 3765 13230 W System.err :13230): at androidx.constraintlayout.core.widgets.ConstraintWidgetContainer.addChildrenToSolver(ConstraintWidgetContainer.java:435) 行 113565: 07-23 15:06:33.087 3765 13230 W System.err :13230): at androidx.constraintlayout.core.widgets.ConstraintWidgetContainer.layout(ConstraintWidgetContainer.java:835) 行 113566: 07-23 15:06:33.087 3765 13230 W System.err :13230): at androidx.constraintlayout.core.widgets.analyzer.BasicMeasure.solveLinearSystem(BasicMeasure.java:160) 行 113567: 07-23 15:06:33.088 3765 13230 W System.err :13230): at androidx.constraintlayout.core.widgets.analyzer.BasicMeasure.solverMeasure(BasicMeasure.java:291) 行 113568: 07-23 15:06:33.088 3765 13230 W System.err :13230): at androidx.constraintlayout.core.widgets.ConstraintWidgetContainer.measure(ConstraintWidgetContainer.java:120) 行 113569: 07-23 15:06:33.088 3765 13230 W System.err :13230): at androidx.constraintlayout.widget.ConstraintLayout.resolveSystem(ConstraintLayout.java:1594) 行 113570: 07-23 15:06:33.088 3765 13230 W System.err :13230): at androidx.constraintlayout.widget.ConstraintLayout.onMeasure(ConstraintLayout.java:1708) 行 113571: 07-23 15:06:33.088 3765 13230 W System.err :13230): at android.view.View.measure(View.java:25090) 行 113572: 07-23 15:06:33.088 3765 13230 W System.err :13230): at com.seres.app.map_resource.adapter.util.ViewToBitmap.layoutView(ViewToBitmap.java:29) 行 113573: 07-23 15:06:33.088 3765 13230 W System.err :13230): at com.seres.app.map_resource.adapter.base.BaseStyleAdapter.l(BaseStyleAdapter.java:315) 行 113574: 07-23 15:06:33.088 3765 13230 W System.err :13230): at com.seres.app.map_resource.adapter.base.BaseStyleAdapter.s(BaseStyleAdapter.java:248) 行 113575: 07-23 15:06:33.088 3765 13230 W System.err :13230): at com.seres.app.map_resource.adapter.base.BaseStyleAdapter.t(BaseStyleAdapter.java:337) 行 113576: 07-23 15:06:33.088 3765 13230 W System.err :13230): at com.seres.app.map_resource.adapter.route.RouteLayerStyleAdapter.onCompareTipStyle(RouteLayerStyleAdapter.java:389) 行 113577: 07-23 15:06:33.088 3765 13230 W System.err :13230): at com.seres.service.navi.map.layers.route.impl.RouteLayer.J1(RouteLayer.java:1456) 行 113578: 07-23 15:06:33.088 3765 13230 W System.err :13230): at com.seres.service.navi.map.layers.route.impl.RouteLayer.C0(Unknown Source:0) 行 113579: 07-23 15:06:33.089 3765 13230 W System.err :13230): at com.seres.service.navi.map.layers.route.impl.h.onWith(Unknown Source:6) 行 113580: 07-23 15:06:33.089 3765 13230 W System.err :13230): at com.seres.service.navi.util.check.TypeCheck.a(TypeCheck.java:46) 行 113581: 07-23 15:06:33.089 3765 13230 W System.err :13230): at com.seres.service.navi.map.layers.route.impl.RouteLayer.Y0(RouteLayer.java:1454) 行 113582: 07-23 15:06:33.089 3765 13230 W System.err :13230): at com.seres.service.navi.map.layers.route.impl.RouteLayer.y2(RouteLayer.java:1101) 行 113583: 07-23 15:06:33.089 3765 13230 W System.err :13230): at com.seres.service.navi.map.layers.route.impl.RouteLayer.E0(RouteLayer.java:134) 行 113584: 07-23 15:06:33.089 3765 13230 W System.err :13230): at com.seres.service.navi.map.layers.route.impl.RouteLayer$1.getLayerStyle(RouteLayer.java:1903) 行 113585: 07-23 15:06:33.089 3765 13230 W System.err :13230): at com.autonavi.gbl.map.router.PrepareLayerStyleRouter.getLayerStyle(PrepareLayerStyleRouter.java:246) 行 113586: 07-23 15:06:33.089 3765 13230 W System.err :13230): at com.autonavi.gbl.map.layer.observer.impl.MapLayerObserverJNI.SwigDirector_IPrepareLayerStyleImpl_getLayerStyle(MapLayerObserverJNI.java:68) 行 113587: 07-23 15:06:33.089 3765 13230 W System.err :13230): at com.autonavi.gbl.layer.impl.IBizControlImpl.updateStyle1Native(Native Method) 行 113588: 07-23 15:06:33.089 3765 13230 W System.err :13230): at com.autonavi.gbl.layer.impl.IBizControlImpl.updateStyle(IBizControlImpl.java:246) 行 113589: 07-23 15:06:33.089 3765 13230 W System.err :13230): at com.autonavi.gbl.layer.BizControl.updateStyle(BizControl.java:434) 行 113590: 07-23 15:06:33.089 3765 13230 W System.err :13230): at com.seres.service.navi.map.layers.route.impl.RouteLayer.o2(RouteLayer.java:898) 行 113591: 07-23 15:06:33.089 3765 13230 W System.err :13230): at com.seres.service.navi.map.layers.route.impl.RouteLayer.C(Unknown Source:0) 行 113592: 07-23 15:06:33.089 3765 13230 W System.err :13230): at com.seres.service.navi.map.layers.route.impl.b1.run(Unknown Source:4) 行 113593: 07-23 15:06:33.089 3765 13230 W System.err :13230): at android.os.Handler.handleCallback(Handler.java:883) 行 113594: 07-23 15:06:33.089 3765 13230 W System.err :13230): at android.os.Handler.dispatchMessage(Handler.java:100) 行 113595: 07-23 15:06:33.090 3765 13230 W System.err :13230): at android.os.Looper.loop(Looper.java:214) 行 113596: 07-23 15:06:33.090 3765 13230 W System.err :13230): at android.os.HandlerThread.run(HandlerThread.java:67) 行 113597: 07-23 15:06:33.090 3765 13230 I System.out :13230): EXCEPTION : java.lang.NullPointerException: Attempt to read from field 'int androidx.constraintlayout.core.SolverVariable.id' on a null object reference
07-25
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值