NullPointerException View.buildDrawingCache

来源:互联网 发布:网络弊大于利经典提问 编辑:程序博客网 时间:2024/06/13 22:27

最近的项目中,测试说熄屏后再进入界面会出现闪退,将日志拿来看了下,

java.lang.NullPointerExceptionat android.view.View.buildDrawingCache(View.java:13204)at android.view.View.getDrawingCache(View.java:13051)at android.view.View.draw(View.java:13716)at android.view.ViewGroup.drawChild(ViewGroup.java:3154)at android.widget.ListView.drawChild(ListView.java:3306)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3018)at android.widget.AbsListView.dispatchDraw(AbsListView.java:2579)at android.widget.ListView.dispatchDraw(ListView.java:3301)at android.view.View.draw(View.java:14049)at android.widget.AbsListView.draw(AbsListView.java:4140)at android.view.View.draw(View.java:13916)at android.view.ViewGroup.drawChild(ViewGroup.java:3154)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3018)at android.view.View.draw(View.java:14049)at android.view.View.draw(View.java:13916)at android.view.ViewGroup.drawChild(ViewGroup.java:3154)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3018)at android.view.View.draw(View.java:13911)at android.view.ViewGroup.drawChild(ViewGroup.java:3154)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3018)at android.view.View.draw(View.java:13911)at android.view.ViewGroup.drawChild(ViewGroup.java:3154)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3018)at android.view.View.draw(View.java:14049)at android.view.View.draw(View.java:13916)at android.view.ViewGroup.drawChild(ViewGroup.java:3154)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3018)at android.view.View.draw(View.java:13911)at android.view.ViewGroup.drawChild(ViewGroup.java:3154)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3018)at android.view.View.draw(View.java:13911)at android.view.ViewGroup.drawChild(ViewGroup.java:3154)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3018)at android.view.View.draw(View.java:13911)at android.view.ViewGroup.drawChild(ViewGroup.java:3154)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3018)at android.view.View.draw(View.java:13911)at android.view.ViewGroup.drawChild(ViewGroup.java:3154)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3018)at android.view.View.draw(View.java:13911)at android.view.ViewGroup.drawChild(ViewGroup.java:3154)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3018)at android.view.View.draw(View.java:13911)at android.view.ViewGroup.drawChild(ViewGroup.java:3154)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3018)at android.view.View.draw(View.java:13911)at android.view.ViewGroup.drawChild(ViewGroup.java:3154)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3018)at android.view.View.draw(View.java:13911)at android.view.ViewGroup.drawChild(ViewGroup.java:3154)at android.view.ViewGroup.dispatchDraw(ViewGroup.java:3018)at android.view.View.draw(View.java:14049)at android.widget.FrameLayout.draw(FrameLayout.java:467)at com.android.internal.policy.impl.PhoneWindow$DecorView.draw(PhoneWindow.java:2333)at android.view.ViewRootImpl.drawSoftware(ViewRootImpl.java:2698)at android.view.ViewRootImpl.draw(ViewRootImpl.java:2589)at android.view.ViewRootImpl.performDraw(ViewRootImpl.java:2452)at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:2254)at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1246)at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:5014)at android.view.Choreographer$CallbackRecord.run(Choreographer.java:776)at android.view.Choreographer.doCallbacks(Choreographer.java:579)at android.view.Choreographer.doFrame(Choreographer.java:548)at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:762)at android.os.Handler.handleCallback(Handler.java:800)at android.os.Handler.dispatchMessage(Handler.java:100)at android.os.Looper.loop(Looper.java:194)at android.app.ActivityThread.main(ActivityThread.java:5400)at java.lang.reflect.Method.invokeNative(Native Method)at java.lang.reflect.Method.invoke(Method.java:525)at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:853)at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:620)at dalvik.system.NativeStart.main(Native Method)

报出了空指针的问题,在网上找了很久,相关的都是在做截图操作的时候会出现这种问题,我们的项目中没有截图的操作. 于是进入到源码查看,

在上面的注释中可以看到与硬件加速有关,正好我们再代码中将硬件加速关闭了,android:hardwareAccelerated=”false” 使用的这个,

又在网上研究了硬件加速的一些问题,最后发现了这个

应该是这个问题,最后将android:hardwareAccelerated=”false”删除了.

1 0