一、提出需求

有A,B,C三个应用,B中的数据需要被共享,所以B中定义了内容提供者ContentProvider;A应用修改了B应用的数据,插入了一条数据。有这样一个需求,此时C应用需要得到数据被修改的通知并处理相应操作。

二、示例代码

A应用

public class MainActivity extends Activity
{

@Override
 public void onCreate(Bundle savedInstanceState)
 {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.main);
 }

public void insert(View v)
 {
  Uri uri = Uri.parse("content://cn.xyCompany.providers.personProvider/person");
  ContentResolver resolver = this.getContentResolver();
  ContentValues values = new ContentValues();
  values.put("name", "xy_new_new");
  values.put("phone", "xy_new_111");
  resolver.insert(uri, values);
 }
}

B应用
package cn.xy.cotentProvider.app.providers;
import android.content.ContentProvider;
import android.content.ContentUris;
import android.content.ContentValues;
import android.content.UriMatcher;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.net.Uri;
import android.util.Log;
import cn.xy.cotentProvider.service.DBOpeningHelper;

public class PersonProvider extends ContentProvider
{
 private DBOpeningHelper dbHelper;

// 若不匹配采用UriMatcher.NO_MATCH(-1)返回
 private static final UriMatcher MATCHER = new UriMatcher(UriMatcher.NO_MATCH);

// 匹配码
 private static final int CODE_NOPARAM = 1;
 private static final int CODE_PARAM = 2;

static
 {
  // 对等待匹配的URI进行匹配操作,必须符合cn.xyCompany.providers.personProvider/person格式
  // 匹配返回CODE_NOPARAM,不匹配返回-1
  MATCHER.addURI("cn.xyCompany.providers.personProvider", "person", CODE_NOPARAM);

// #表示数字 cn.xyCompany.providers.personProvider/person/10
  // 匹配返回CODE_PARAM,不匹配返回-1
  MATCHER.addURI("cn.xyCompany.providers.personProvider", "person/#", CODE_PARAM);
 }

@Override
 public boolean onCreate()
 {
  dbHelper = new DBOpeningHelper(this.getContext());
  return true;
 }

@Override
 public Uri insert(Uri uri, ContentValues values)
 {
  SQLiteDatabase db = dbHelper.getWritableDatabase();
  switch (MATCHER.match(uri))
  {
   case CODE_NOPARAM:
    // 若主键值是自增长的id值则返回值为主键值,否则为行号,但行号并不是RecNo列
    long id = db.insert("person", "name", values);
    Uri insertUri = ContentUris.withAppendedId(uri, id);
    // 发出变化通知(非必须)设监听者为null。
    // 若设置某个监听者则不管有多少个监听者,该监听者一定可以获得该通知
    getContext().getContentResolver().notifyChange(uri, null);
    return insertUri;
   default:
    throw new IllegalArgumentException("this is unkown uri:" + uri);
  }
 }
 ......
}

C应用
package cn.xt.contentProvider.lisenter;
import android.app.Activity;
import android.content.ContentResolver;
import android.database.ContentObserver;
import android.database.Cursor;
import android.net.Uri;
import android.os.Bundle;
import android.os.Handler;
import android.util.Log;

public class MainActivity extends Activity
{
 @Override
 public void onCreate(Bundle savedInstanceState)
 {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.main);
  Uri uri = Uri.parse("content://cn.xyCompany.providers.personProvider/person");
  ContentResolver resolver = this.getContentResolver();
  resolver.registerContentObserver(uri, true, new PersonContentObserver(new Handler()));
 }

private class PersonContentObserver extends ContentObserver
 {
  public PersonContentObserver(Handler handler)
  {
   super(handler);
  }

// 得到数据的变化通知,该方法只能粗略知道数据的改变,并不能判断是哪个业务操作进行的改变
  @Override
  public void onChange(boolean selfChange)
  {
   // select * from person order by id desc limit 1 // 取得最近插入的值(序号大——>小并取第一个)
   Uri uri = Uri.parse("content://cn.xyCompany.providers.personProvider/person");
   ContentResolver resolver = MainActivity.this.getContentResolver();
   Cursor cursor = resolver.query(uri, null, null, null, "id desc limit 1");
   if(cursor.moveToFirst())
   {
    String name = cursor.getString(cursor.getColumnIndex("name"));
    Log.i("lisenter", name);
   }
  }
 }
}

关于contentProvider的基本使用,请参看本博客博文《Android开发13——内容提供者ContentProvider的基本使用》

http://blog.sina.com.cn/s/blog_67aaf444010162bj.html

Android开发14——监听内容提供者ContentProvider的数据变化的更多相关文章

  1. [Android Pro] 监听内容提供者ContentProvider的数据变化

    转载自:http://blog.csdn.net/woshixuye/article/details/8281385 一.提出需求 有A,B,C三个应用,B中的数据需要被共享,所以B中定义了内容提供者 ...

  2. Android开发之监听发出的短信

    执行效果图: 预备知识: 为了监听指定的ContentProvider的数据的改变,须要通过ContentResolver向指定Uri注冊CotentObserver监听器.ContentResolv ...

  3. Android开发-之监听button点击事件

    一.实现button点击事件的方法 实现button点击事件的监听方法有很多种,这里总结了常用的四种方法: 1.匿名内部类 2.外部类(独立类) 3.实现OnClickListener接口 4.添加X ...

  4. android开发事件监听

    第一种:匿名内部类作为事件监听器类 大部分时候,事件处理器都没有什么利用价值(可利用代码通常都被抽象成了业务逻辑方法),因此大部分事件监听器只是临时使用一次,所以使用匿名内部类形式的事件监听器更合适, ...

  5. 【Android开发】监听图库数据库的变化

    步骤一: 保存图片或者删除之前,初始化ContentObserver ScreenshotContentObserver mScreenObserver = new ScreenshotContent ...

  6. Android 短信监听及用途分析

    监听系统短信这个只能作为一个技术点来研究下,读者可能在工作中可能不会哦涉及到,一般的应用软件也不会有这个需求 但是作为程序员呢,多了解一下也是好的. Android 监听系统短信有什么用? 1.对系统 ...

  7. vue 监听对象里的特定数据

    vue  监听对象里的特定数据变化 通常是这样写的,只能监听某一个特定数据 watch: { params: function(val) { console.log(val) this.$ajax.g ...

  8. 无废话Android之listview入门,自定义的数据适配器、采用layoutInflater打气筒创建一个view对象、常用数据适配器ArrayAdapter、SimpleAdapter、使用ContentProvider(内容提供者)共享数据、短信的备份、插入一条记录到系统短信应用(3)

    1.listview入门,自定义的数据适配器 <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/and ...

  9. Android零基础入门第34节:Android中基于监听的事件处理

    原文:Android零基础入门第34节:Android中基于监听的事件处理 上一期我们学习了Android中的事件处理,也详细学习了Android中基于监听的事件处理,同时学会了匿名内部类形式,那么本 ...

随机推荐

  1. BZOJ 3172 Tjoi2013 单词 后缀数组

    题目大意:给定一个n个单词的文章,求每一个单词在文章中的出现次数 文章长度<=10^6(不是单词长度<=10^6,不然读入直接超时) 首先将全部单词用空格连接成一个字符串.记录每一个单词的 ...

  2. IDEA+Gradle相关资料

    要注意下载的版本,不能过于陈旧,否则会报错,导致无法正常配置. 具体配置参考:https://my.oschina.net/u/1994816/blog/297967 IDEA下载地址:https:/ ...

  3. 微信小程序 - 获取所在位置(省、市、区)

    实现步骤 1. 获取当前经纬度 2. 调用腾讯(百度.高德)地图对应的请求地址,一般都会有独一的key, 譬如 腾讯地图调用地址: https://apis.map.qq.com/ws/geocode ...

  4. Hibernate(十一)检索

    一.Hibernate检索策略 二.检索方法 三.get和load比较 get和load的区别:  get不支持延迟加载,而load支持.  当查询特定的数据库中不存在的数据时,get会返回null, ...

  5. android:View的setTag和getTag使用

    1.用于区分非常多类似的View 比如: button1.setOnClickListener(new OnClickListener ... ); button2.setOnClickListene ...

  6. 关于"引用"的几点说明

    一.引用的基本知识 引用就是某一变量(目标)的一个别名,对引用的操作与对变量直接操作完全一样.引用的声明方法:类型标识符 &引用名=目标变量名: 说明: (1)&在此不是求地址运算,而 ...

  7. 【Linux】别名

    别名就是一种快捷方式,以省去用户输入一长串命令的麻烦. 别名有多种实现方式,可以使用函数,也可以使用alias命令 注意:alias命令的作用只是短暂的.一旦终端关闭,别名则失效,如果要让别名永久生效 ...

  8. 如何提高SELECT的效率

      首先避免使用in ,not in,<>,<,<=,>,>=,is null,is not null 主要搜索字段建立索引 .WHERE子句中的连接顺序 sql解 ...

  9. (转)J2EE十三个技术规范

    从事Java开发的童鞋都知道,java是一种非常棒的语言,能够实现跨平台运行.它屏蔽了具体的平台环境的要求,也就是说,无论是windows,还是Unix.Linux系统,只要支持Java虚拟机,就可以 ...

  10. Systemd 基础(转)

    Systemd 是 Linux 系统工具,用来启动守护进程,已成为大多数发行版的标准配置. 原文链接:http://www.ruanyifeng.com/blog/2016/03/systemd-tu ...