Handler使用过程中出现的问题

    在上篇文章中之所以转载文章,是因为我打算写这篇Handler在使用过程中出现的问题,整理网上的资料的时候,很多人混淆了内存泄漏和溢出的概念。这里我在明确一下:

   **Hanlder使用不当不会马上引起内存溢出,但是会引起内存泄漏,Hanlder使用不当不会马上引起内存溢出,但是会引起内存泄漏,Hanlder使用不当不会马上引起内存溢出,但是会引起内存泄漏,好了,长长的舒一口气,重要的事情要说三遍**

方法一:通过程序逻辑来进行保护。

1.在关闭Activity的时候停掉你的后台线程。线程停掉了,就相当于切断了Handler和外部连接的线,Activity自然会在合适的时候被回收。

2.如果你的Handler是被delay的Message持有了引用,那么使用相应的Handler的removeCallbacks()方法,把消息对象从消息队列移除就行了。

方法二:将Handler声明为静态类。

静态类不持有外部类的对象,所以你的Activity可以随意被回收。代码如下:

static class MyHandler extends Handler {
@Override
public void handleMessage(Message msg) {
mImageView.setImageBitmap(mBitmap);
} } 但其实没这么简单。使用了以上代码之后,你会发现,由于Handler不再持有外部类对象的引用,导致程序不允许你在Handler中操作Activity中的对象了。所以你需要在Handler中增加一个对Activity的弱引用(WeakReference):

static class MyHandler extends Handler {
WeakReference mActivityReference;

MyHandler(Activity activity) {
    mActivityReference= new WeakReference<Activity>(activity);
}

@Override
public void handleMessage(Message msg) {
    final Activity activity = mActivityReference.get();
    if (activity != null) {
        mImageView.setImageBitmap(mBitmap);
    }
} }

后续在这篇文章中再针对Handler的源码进行分析,完善,总结。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在MySQL,CONTINUE HANDLER是一种错误处理机制,用于在存储过程或函数捕获并处理异常。它允许我们在出现异常时继续执行后续的语句,而不是立即断程序的执行。 CONTINUE HANDLER的用法如下: 1. 定义CONTINUE HANDLER:在存储过程或函数的BEGIN...END语句块内,使用DECLARE CONTINUE HANDLER语句定义一个异常处理器。 ```sql DECLARE <condition> HANDLER FOR <exception> BEGIN -- 异常处理逻辑 END; ``` 这里,`<condition>` 是一个局部变量,可用于在异常处理程序获取异常的详细信息;`<exception>` 是指定要捕获的异常类型。 2. 编写异常处理逻辑:在 `BEGIN...END` 语句块内编写异常处理逻辑,以处理指定类型的异常。可以在异常处理程序执行需要的操作,如记录日志、回滚事务、输出错误消息等。 ```sql DECLARE CONTINUE HANDLER FOR SQLEXCEPTION BEGIN -- 异常处理逻辑 END; ``` 在上面的示例,我们使用 `SQLEXCEPTION` 来捕获任何SQL异常。 3. 使用CONTINUE HANDLER:在存储过程或函数的执行过程,当发生指定类型的异常时,CONTINUE HANDLER会被触发,并执行相应的异常处理逻辑。 ```sql BEGIN -- 执行语句 -- ... END; ``` 当在 `BEGIN...END` 语句块内出现异常时,异常处理程序会被调用,然后程序会继续执行后续的语句。 需要注意的是,CONTINUE HANDLER只能捕获指定类型的异常,并且只能在存储过程或函数使用。它不能用于触发器或其他类型的SQL语句。 以上是CONTINUE HANDLER的基本用法。通过使用CONTINUE HANDLER,我们可以更好地控制程序的执行流程,在出现异常时进行适当的处理,而不会导致整个程序的断。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值