java.lang.RuntimeException: Canvas: trying to use a recycled bitmap

2024-06-04 00:32

本文主要是介绍java.lang.RuntimeException: Canvas: trying to use a recycled bitmap,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

错误提示如题

具体错误内容如下:

08-10 12:21:00.370: E/InputEventReceiver(16613): Exception dispatching input event.
08-10 12:21:00.370: E/MessageQueue-JNI(16613): Exception in MessageQueue callback: handleReceiveCallback
08-10 12:21:00.377: E/MessageQueue-JNI(16613): java.lang.RuntimeException: Canvas: trying to use a recycled bitmap android.graphics.Bitmap@41bd0800
08-10 12:21:00.377: E/MessageQueue-JNI(16613): 	at android.graphics.Canvas.throwIfRecycled(Canvas.java:1026)
08-10 12:21:00.377: E/MessageQueue-JNI(16613): 	at android.graphics.Canvas.drawBitmap(Canvas.java:1096)
08-10 12:21:00.377: E/MessageQueue-JNI(16613): 	at android.graphics.Bitmap.createBitmap(Bitmap.java:604)
08-10 12:21:00.377: E/MessageQueue-JNI(16613): 	at com.android.francis.gesture.listener.CustomGestureListener.onFling(CustomGestureListener.java:55)
08-10 12:21:00.377: E/MessageQueue-JNI(16613): 	at android.view.GestureDetector.onTouchEvent(GestureDetector.java:1387)
08-10 12:21:00.377: E/MessageQueue-JNI(16613): 	at com.android.francis.gesture.MainActivity.onTouchEvent(MainActivity.java:31)
08-10 12:21:00.377: E/MessageQueue-JNI(16613): 	at android.app.Activity.dispatchTouchEvent(Activity.java:2471)
08-10 12:21:00.377: E/MessageQueue-JNI(16613): 	at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchTouchEvent(PhoneWindow.java:2061)
08-10 12:21:00.377: E/MessageQueue-JNI(16613): 	at android.view.View.dispatchPointerEvent(View.java:7525)
08-10 12:21:00.377: E/MessageQueue-JNI(16613): 	at android.view.ViewRootImpl.deliverPointerEvent(ViewRootImpl.java:3370)
08-10 12:21:00.377: E/MessageQueue-JNI(16613): 	at android.view.ViewRootImpl.deliverInputEvent(ViewRootImpl.java:3302)
08-10 12:21:00.377: E/MessageQueue-JNI(16613): 	at android.view.ViewRootImpl.doProcessInputEvents(ViewRootImpl.java:4394)
08-10 12:21:00.377: E/MessageQueue-JNI(16613): 	at android.view.ViewRootImpl.enqueueInputEvent(ViewRootImpl.java:4372)
08-10 12:21:00.377: E/MessageQueue-JNI(16613): 	at android.view.ViewRootImpl$WindowInputEventReceiver.onInputEvent(ViewRootImpl.java:4476)
08-10 12:21:00.377: E/MessageQueue-JNI(16613): 	at android.view.InputEventReceiver.dispatchInputEvent(InputEventReceiver.java:171)
08-10 12:21:00.377: E/MessageQueue-JNI(16613): 	at android.os.MessageQueue.nativePollOnce(Native Method)
08-10 12:21:00.377: E/MessageQueue-JNI(16613): 	at android.os.MessageQueue.next(MessageQueue.java:125)
08-10 12:21:00.377: E/MessageQueue-JNI(16613): 	at android.os.Looper.loop(Looper.java:124)
08-10 12:21:00.377: E/MessageQueue-JNI(16613): 	at android.app.ActivityThread.main(ActivityThread.java:4895)
08-10 12:21:00.377: E/MessageQueue-JNI(16613): 	at java.lang.reflect.Method.invokeNative(Native Method)
08-10 12:21:00.377: E/MessageQueue-JNI(16613): 	at java.lang.reflect.Method.invoke(Method.java:511)
08-10 12:21:00.377: E/MessageQueue-JNI(16613): 	at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:994)
08-10 12:21:00.377: E/MessageQueue-JNI(16613): 	at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:761)
08-10 12:21:00.377: E/MessageQueue-JNI(16613): 	at dalvik.system.NativeStart.main(Native Method)

好长的一段提示信息,根据提示信息我们可以定位到错误位置:手动释放Bitmap对象中的图片资源造成的。

看程序代码:

//		判断图片资源是否被回收if (drawable != null && !drawable.getBitmap().isRecycled()) {
//			强制回收图片资源drawable.getBitmap().recycle();}

既然是手动释放Bitmap对象中的资源文件造成的错误,第一个解决方案就是:

我们就不要自己来做这个释放操作了,留给程序自己做吧,上面这段代码全部注释掉

测试结果OK,成功的。

第二个解决方案,看代码:

//		判断图片资源是否被回收if (drawable != null && !drawable.getBitmap().isRecycled()) {
//			强制回收图片资源
//			drawable.getBitmap().recycle();Bitmap bm = drawable.getBitmap();bm = null;}

获取当前的Bitmap对象,然后赋予null值,程序测试OK。

如果还有其他Bug、高见,请各位留言。

为嘛手动释放就错误,我也不清楚,知道的大侠也可以留言。

这篇关于java.lang.RuntimeException: Canvas: trying to use a recycled bitmap的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1028552

相关文章

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

SpringCloud动态配置注解@RefreshScope与@Component的深度解析

《SpringCloud动态配置注解@RefreshScope与@Component的深度解析》在现代微服务架构中,动态配置管理是一个关键需求,本文将为大家介绍SpringCloud中相关的注解@Re... 目录引言1. @RefreshScope 的作用与原理1.1 什么是 @RefreshScope1.

Java并发编程必备之Synchronized关键字深入解析

《Java并发编程必备之Synchronized关键字深入解析》本文我们深入探索了Java中的Synchronized关键字,包括其互斥性和可重入性的特性,文章详细介绍了Synchronized的三种... 目录一、前言二、Synchronized关键字2.1 Synchronized的特性1. 互斥2.

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

Java中StopWatch的使用示例详解

《Java中StopWatch的使用示例详解》stopWatch是org.springframework.util包下的一个工具类,使用它可直观的输出代码执行耗时,以及执行时间百分比,这篇文章主要介绍... 目录stopWatch 是org.springframework.util 包下的一个工具类,使用它

Java进行文件格式校验的方案详解

《Java进行文件格式校验的方案详解》这篇文章主要为大家详细介绍了Java中进行文件格式校验的相关方案,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、背景异常现象原因排查用户的无心之过二、解决方案Magandroidic Number判断主流检测库对比Tika的使用区分zip

Java实现时间与字符串互相转换详解

《Java实现时间与字符串互相转换详解》这篇文章主要为大家详细介绍了Java中实现时间与字符串互相转换的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、日期格式化为字符串(一)使用预定义格式(二)自定义格式二、字符串解析为日期(一)解析ISO格式字符串(二)解析自定义

Java使用Curator进行ZooKeeper操作的详细教程

《Java使用Curator进行ZooKeeper操作的详细教程》ApacheCurator是一个基于ZooKeeper的Java客户端库,它极大地简化了使用ZooKeeper的开发工作,在分布式系统... 目录1、简述2、核心功能2.1 CuratorFramework2.2 Recipes3、示例实践3

Springboot处理跨域的实现方式(附Demo)

《Springboot处理跨域的实现方式(附Demo)》:本文主要介绍Springboot处理跨域的实现方式(附Demo),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录Springboot处理跨域的方式1. 基本知识2. @CrossOrigin3. 全局跨域设置4.

springboot security使用jwt认证方式

《springbootsecurity使用jwt认证方式》:本文主要介绍springbootsecurity使用jwt认证方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录前言代码示例依赖定义mapper定义用户信息的实体beansecurity相关的类提供登录接口测试提供一