Android应用开发之(小技巧之LocalBroadcastManager)

Android v4 兼容包提供android.support.v4.content.LocalBroadcastManager工具类,帮助大家在自己的进程内进行局部广播发送与注册,使用它比直接通过sendBroadcast(Intent)发送系统全局广播有以下几点好处。

1    因广播数据在本应用范围内传播,你不用担心隐私数据泄露的问题。

2    不用担心别的应用伪造广播,造成安全隐患。

3    相比在系统内发送全局广播,它更高效。

使用方法 通过getInstance(Contextcontext)获取实例,demo如下:

/**

* Demonstrates the use of a LocalBroadcastManager to easily communicate

* data from a service to any other interested code.

*/

public class LocalServiceBroadcaster extends Activity {

static final String ACTION_STARTED = "com.example.android.supportv4.STARTED";

static final String ACTION_UPDATE = "com.example.android.supportv4.UPDATE";

static final String ACTION_STOPPED = "com.example.android.supportv4.STOPPED";

LocalBroadcastManager mLocalBroadcastManager;

BroadcastReceiver mReceiver;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.local_service_broadcaster);

// This is where we print the data we get back.

final TextView callbackData = (TextView)findViewById(R.id.callback);

// Put in some initial text.

callbackData.setText("No broadcast received yet");

// We use this to send broadcasts within our local process.

mLocalBroadcastManager = LocalBroadcastManager.getInstance(this);

// We are going to watch for interesting local broadcasts.

IntentFilter filter = new IntentFilter();

filter.addAction(ACTION_STARTED);

filter.addAction(ACTION_UPDATE);

filter.addAction(ACTION_STOPPED);

mReceiver = new BroadcastReceiver() {

@Override

public void onReceive(Context context, Intent intent) {

if (intent.getAction().equals(ACTION_STARTED)) {

callbackData.setText("STARTED");

} else if (intent.getAction().equals(ACTION_UPDATE)) {

callbackData.setText("Got update: " + intent.getIntExtra("value", 0));

} else if (intent.getAction().equals(ACTION_STOPPED)) {

callbackData.setText("STOPPED");

}

}

};

mLocalBroadcastManager.registerReceiver(mReceiver, filter);

// Watch for button clicks.

Button button = (Button)findViewById(R.id.start);

button.setOnClickListener(mStartListener);

button = (Button)findViewById(R.id.stop);

button.setOnClickListener(mStopListener);

}

@Override

protected void onDestroy() {

super.onDestroy();

mLocalBroadcastManager.unregisterReceiver(mReceiver);

}

private OnClickListener mStartListener = new OnClickListener() {

public void onClick(View v) {

startService(new Intent(LocalServiceBroadcaster.this, LocalService.class));

}

};

private OnClickListener mStopListener = new OnClickListener() {

public void onClick(View v) {

stopService(new Intent(LocalServiceBroadcaster.this, LocalService.class));

}

};

public static class LocalService extends Service {

LocalBroadcastManager mLocalBroadcastManager;

int mCurUpdate;

static final int MSG_UPDATE = 1;

Handler mHandler = new Handler() {

@Override

public void handleMessage(Message msg) {

switch (msg.what) {

case MSG_UPDATE: {

mCurUpdate++;

Intent intent = new Intent(ACTION_UPDATE);

intent.putExtra("value", mCurUpdate);

mLocalBroadcastManager.sendBroadcast(intent);

Message nmsg = mHandler.obtainMessage(MSG_UPDATE);

mHandler.sendMessageDelayed(nmsg, 1000);

} break;

default:

super.handleMessage(msg);

}

}

};

@Override

public void onCreate() {

super.onCreate();

mLocalBroadcastManager = LocalBroadcastManager.getInstance(this);

}

public int onStartCommand(Intent intent, int flags, int startId) {

// Tell any local interested parties about the start.

mLocalBroadcastManager.sendBroadcast(new Intent(ACTION_STARTED));

// Prepare to do update reports.

mHandler.removeMessages(MSG_UPDATE);

Message msg = mHandler.obtainMessage(MSG_UPDATE);

mHandler.sendMessageDelayed(msg, 1000);

return ServiceCompat.START_STICKY;

}

@Override

public void onDestroy() {

super.onDestroy();

// Tell any local interested parties about the stop.

mLocalBroadcastManager.sendBroadcast(new Intent(ACTION_STOPPED));

// Stop doing updates.

mHandler.removeMessages(MSG_UPDATE);

}

@Override

public IBinder onBind(Intent intent) {

return null;

}

}

}

  转自 Android Club

LocalBroadcastManager 的简单介绍的更多相关文章

  1. Android中Intent具体解释(二)之使用Intent广播事件及Broadcast Receiver简单介绍

    通过第一篇的解说,我们已经看到了怎样使用Intent来启动新的应用程序组件,可是实际上他们也能够使用sendBroadcast方法来在组件间匿名的广播消息. 作为一个系统级别的消息传递机制,Inten ...

  2. [原创]关于mybatis中一级缓存和二级缓存的简单介绍

    关于mybatis中一级缓存和二级缓存的简单介绍 mybatis的一级缓存: MyBatis会在表示会话的SqlSession对象中建立一个简单的缓存,将每次查询到的结果结果缓存起来,当下次查询的时候 ...

  3. 利用Python进行数据分析(7) pandas基础: Series和DataFrame的简单介绍

    一.pandas 是什么 pandas 是基于 NumPy 的一个 Python 数据分析包,主要目的是为了数据分析.它提供了大量高级的数据结构和对数据处理的方法. pandas 有两个主要的数据结构 ...

  4. 利用Python进行数据分析(4) NumPy基础: ndarray简单介绍

    一.NumPy 是什么 NumPy 是 Python 科学计算的基础包,它专为进行严格的数字处理而产生.在之前的随笔里已有更加详细的介绍,这里不再赘述. 利用 Python 进行数据分析(一)简单介绍 ...

  5. yii2的权限管理系统RBAC简单介绍

    这里有几个概念 权限: 指用户是否可以执行哪些操作,如:编辑.发布.查看回帖 角色 比如:VIP用户组, 高级会员组,中级会员组,初级会员组 VIP用户组:发帖.回帖.删帖.浏览权限 高级会员组:发帖 ...

  6. angular1.x的简单介绍(二)

    首先还是要强调一下DI,DI(Denpendency Injection)伸手获得,主要解决模块间的耦合关系.那么模块是又什么组成的呢?在我看来,模块的最小单位是类,多个类的组合就是模块.关于在根模块 ...

  7. Linux的简单介绍和常用命令的介绍

    Linux的简单介绍和常用命令的介绍 本说明以Ubuntu系统为例 Ubuntu系统的安装自行百度,或者参考http://www.cnblogs.com/CoderJYF/p/6091068.html ...

  8. iOS-iOS开发简单介绍

    概览 终于到了真正接触IOS应用程序的时刻了,之前我们花了很多时间去讨论C语言.ObjC等知识,对于很多朋友而言开发IOS第一天就想直接看到成果,看到可以运行的IOS程序.但是这里我想强调一下,前面的 ...

  9. iOS开发多线程篇—多线程简单介绍

    iOS开发多线程篇—多线程简单介绍 一.进程和线程 1.什么是进程 进程是指在系统中正在运行的一个应用程序 每个进程之间是独立的,每个进程均运行在其专用且受保护的内存空间内 比如同时打开QQ.Xcod ...

随机推荐

  1. pdf.js跨域加载文件

    pdf.js一个基于Html的工具类,熟悉pdf.js的朋友们很清楚,pdf.js帮助我们做了很多事.尤其金融类网站会产生很多的报表.需要在线预览.pdf.js绝对是我们的首选 本地预览 在pdf.j ...

  2. String与new String()的区别

    JVM为了提升性能和减少内存开销,避免字符串的重复创建,维护了一块特殊的内存空间——字符串实例池. String赋值的两种方式. 1.String str = "test"; 以这 ...

  3. Unable to load template file 'rj\ThinkPHP/Tpl/dispatch_jump.tpl'----thinkphp3.2.3

    Unable to load template file 'rj\ThinkPHP/Tpl/dispatch_jump.tpl'----thinkphp3.2.3 1.报错原因:将thinkphp默认 ...

  4. linux下搭建LJMT(图文版)

    一.  安装VM14 1.1 安装虚拟机vm14(略) 输入序列号:AC5XK-0ZD4H-088HP-9NQZV-ZG2R4(可自行百度) 二. 安装centos详细步骤 2.1安装centos.( ...

  5. hbase rowkey 设计

    HBase中的rowkey是按字典顺序排序的,通过rowkey查询可以对千万级的数据实现毫秒级响应.然而,如果rowkey设计不合理的话经常会出现一个很普遍的问题----热点.当大量client的请求 ...

  6. Hbase多版本(version)数据写入和读取

    1. 首先创建一个支持多版本的hbase表 create }   2.put几条测试数据 put ','f1:name','jack1' put ','f1:name','jack2' 3.读取多版本 ...

  7. python相关,各种命令集合

    PS: cmd必须管理员身份运行 python版本 2.7  可能会出现编码问题:在 Lib/site-packages 新建文件 sitecustomize.py import sys  sys.s ...

  8. 危险的Hystrix线程池

    本文介绍Hystrix线程池的工作原理和参数配置,指出存在的问题并提供规避方案,阅读本文需要对Hystrix有一定的了解. 文本讨论的内容,基于hystrix 1.5.18: <dependen ...

  9. 用java自制简易线程池(不依赖concurrent包)

    很久之前人们为了继续享用并行化带来的好处而不想使用进程,于是创造出了比进程更轻量级的线程.以linux为例,创建一个进程需要申请新的自己的内存空间,从父进程拷贝一些数据,所以开销是比较大的,线程(或称 ...

  10. Kali-Linux-美化与优化

    照理说,linux的桌面是不应当存在在这个世界上的,作为一个linux用户,一味捣鼓桌面显得hin-不专业.但是,虚拟机要用到,浏览器要用到--更何况,自己的老婆能不打扮一下么? update:201 ...