zoukankan      html  css  js  c++  java
  • android cursor和cursoradapter的监听机制

    本文部分参考 http://www.cnblogs.com/ufocdy/archive/2011/03/17/1987327.html 

    主要是以简单的语言说明cursor和cursorAdapter的监听机制

    先来讲讲cursor的监听机制,

    给cursor加监听很简单,调用cursor.registerContentOberserver()即可,然后重写onChange()方法,这样数据库变化,就会回调onChange方法

    背后的监听机制是什么呢?

    cursor是接口,实现应该是在AbstractCursor里面,AbstractCursor有一个ContentObservable继承自Observable,这个就是经典的观察者模式了,

    调用这个方法后,会向这里注册一个观察者,来监控数据库

    现在有观察者了,那数据库变化,又是怎么通知过来的呢?

    还记得自定义provider的时候,有一句必须要加的话不?在add和update和delete的时候--->cur.setNotificationUri(getContext().getContentResolver(), uri);

    这里就是通知observer数据库变化的,其实是通知AbstractCursor的setNotificationUri

    public void setNotificationUri(ContentResolver cr, Uri notifyUri) {
            synchronized (mSelfObserverLock) {
                mNotifyUri = notifyUri;
                mContentResolver = cr;
                if (mSelfObserver != null) {
                    mContentResolver.unregisterContentObserver(mSelfObserver);
                }
                mSelfObserver = new SelfContentObserver(this); 
                mContentResolver.registerContentObserver(mNotifyUri, true, mSelfObserver); 
                mSelfObserverRegistered = true;
            }
        }

    然后上面我们不是刚好通过cursor在这个AbstractCursor中加入了观察者么?原来世界如此美好,数据库的变化一切尽在监控之中

    再来说说cursorAdapter的监听

    cursorAdapter自己内部已经做好了监听,你想在数据库变化后做一些改变,只要重写onContentChanged()即可

    那么它是如何监听的呢?

    其实他的机制和上面的cursor是一样,在你调用cusoradapeter.changeCursor方法的时候,系统会调用一个cursorAdapter.registerContentObserver和registerDatasetObserver,同时取消上次注册的监听

    然后呢?然后就没有然后了,你坐等数据库变化就可以了

  • 相关阅读:
    获取到某一方法的调用者的类名、方法名、命名空间(转)
    JQ插件收集
    输出KnownColor枚举颜色值
    SQL 优化之该走索引却不走索引的分析
    oracle日期处理(一)
    ORACLE如何使用DBMS_METADATA.GET_DDL获取DDL语句
    案例分析:ora04031与ora04030错误分析与解决
    分区表、分区索引和全局索引部分总结
    Oracle性能调整指导纲要
    ORACLE常用SQL优化hint语句
  • 原文地址:https://www.cnblogs.com/xiaoQLu/p/2570934.html
Copyright © 2011-2022 走看看