Android 常驻与非常驻型广播的区别,及ListView优化,Android新手基本知识巩固

1.常驻型广播

常驻型广播,当你的应用程序关闭了,如果有广播信息来,你写的广播接收器同样的能接受到,

他的注册方式就是在你的应用程序中的AndroidManifast.xml进行注册。通常说这种方式是静态注册

下面是配置例子

2<receiver android:name=".widget.DeskWidgeWeather">
3<meta-data android:name="android.appwidget.provider" android:resource="@xml/widget_weather_provider" />
4<intent-filter>
5 <action android:name="android.appwidget.action.APPWIDGET_UPDATE"/>
6 <action android:name="action_weather"/>
7</intent-filter>
8lt;/receiver>  

2.非常驻型广播

当应用程序结束了,广播自然就没有了,比如你在activity中的onCreate或者onResume中注册广播接收器

在onDestory中卸载广播接收器。这样你的广播接收器就一个非常驻型的了。这种也叫动态注册。

比如写一个监听SDcard状态的广播接收器

9SdcardStateChanageReceiver sdcardStateReceiver;
[email protected]
11protected void onCreate(Bundle savedInstanceState)
12{
13 super.onCreate(savedInstanceState);
14 IntentFilter filter = new IntentFilter();
15 filter.addAction(Intent.ACTION_MEDIA_REMOVED);
16 filter.addAction(Intent.ACTION_MEDIA_EJECT);
17 filter.addAction(Intent.ACTION_MEDIA_MOUNTED);
18 filter.addDataScheme("file");
19 sdcardStateReceiver = new SdcardStateChanageReceiver();
20 registerReceiver(sdcardStateReceiver,filter);
21}
[email protected]
23protected void onDestroy(){
24 unregisterReceiver(sdcardStateReceiver);
25}
26class SdcardStateChanageReceiver  extends BroadcastReceiver{
27
28 @Override
29 public void onReceive(Context context, Intent intent)
30 {
31  String state=android.os.Environment.getExternalStorageState();
32  System.out.println("SDCard 发生改变! 状态:"+state);
33  //checkSDCard();
34 }
35 public void checkSDCard(){
36  String state=android.os.Environment.getExternalStorageState();
37  System.out.println(state);
38  if(state.equals(android.os.Environment.MEDIA_REMOVED ) || state .equals(android.os.Environment.MEDIA_UNMOUNTED)){
39   System.out.println("SDCard 已卸载!");
40  }
41 }
42} 

ListView优化方法之一

写一个ViewHolder 内部类把需要重复用到的View放进去,ViewHolder Tag把标记这些View

content provider如何发送信息

用一个Intent意图的PutExtra()方法把消息加进去,注册一个BroadCastRecriver接收消息,更新Activity中的信息

安卓生命周期分哪几种

1. 前台进程。这样的进程拥有一个在屏幕上显示并和用户交互的 activity 或者它的一个IntentReciver 正在运行。这样的程序重要性最高,只有在系统内存非常低,万不得已时才会被结束。

2. 可见进程。在屏幕上显示,但是不在前台的程序。比如一个前台进程以对话框的形式显示在该进程前面。这样的进程也很重要,它们只有在系统没有足够内存运行所有前台进程时,才会被结束。

3. 服务进程。这样的进程在后台持续运行,比如后台音乐播放、后台数据上传下载等。这样的进程对用户来说一般很有用,所以只有当系统没有足够内存来维持所有的前台和可见进程时,才会被结束。

4. 后台进程。这样的程序拥有一个用户不可见的 activity。这样的程序在系统内存不足时,按照 LRU的顺序被结束。

5. 空进程。这样的进程不包含任何活动的程序部件。系统可能随时关闭这类进程。

示例图:

很多基础知识都是我们日常开发用得到的,不要忽视了,其实有时候它们起着很重要的作用,比如ListView就是我们常用的

时间: 2024-10-01 04:44:34

Android 常驻与非常驻型广播的区别,及ListView优化,Android新手基本知识巩固的相关文章

Android 常驻与很驻型广播的差别,及ListView优化,Android新手基本知识巩固

1.常驻型广播 常驻型广播,当你的应用程序关闭了,假设有广播信息来,你写的广播接收器相同的能接受到. 他的注冊方式就是在你的应用程序中的AndroidManifast.xml进行注冊. 通常说这样的方式是静态注冊 以下是配置样例 2<receiver android:name=".widget.DeskWidgeWeather"> 3<meta-data android:name="android.appwidget.provider" andro

Android 两种注册、发送广播的区别

前言:前面文章记录了Service的使用,这次来记录另一个四个组件之一的BroadcastReceiver.主要介绍两种发送和注册广播的区别. BroadcastReceiver广播接收者用于接收系统或其他程序(包括自己程序)发送的广播. 一.注册广播 在android中,我们如果想接收到广播信息,必须自定义我们的广播接收者.要写一个类来继承BroadcastReceiver,并且重写其onReceive()方法,实现接收到特定广播所要做的事情. 这是一个自定义的广播接收者: public cl

Android 进程常驻(5)----开机广播的简单守护以及总结

这是一个轻量级的库,配置几行代码.就能够实如今android上实现进程常驻,也就是在系统强杀下,以及360获取root权限下.clean master获取root权限下都无法杀死进程 支持系统2.3到6.0 支持大部分设备,包含三星.华为.oppo,nexus.魅族等等 能够简单对开机广播进行保护 github地址: https://github.com/Marswin/MarsDaemon 原理分析: Android 进程常驻(0)----MarsDaemon使用说明 Android 进程常驻

Android 编程下两种方式注册广播的区别

常驻型广播 常驻型广播,当你的应用程序关闭了,如果有广播信息来,你写的广播接收器同样的能接收到,它的注册方式就是在你应用程序的AndroidManifast.xml 中进行注册,这种注册方式通常又被称作静态注册.这种方式可以理解为通过清单文件注册的广播是交给操作系统去处理的.示例代码如下: <!-- 订阅开机结束广播 --> <receiver android:name=".receiver.BootCompleteReceiver" > <intent-

转 Android 编程下两种方式注册广播的区别

常驻型广播 常驻型广播,当你的应用程序关闭了,如果有广播信息来,你写的广播接收器同样的能接收到,它的注册方式就是在你应用程序的AndroidManifast.xml 中进行注册,这种注册方式通常又被称作静态注册.这种方式可以理解为通过清单文件注册的广播是交给操作系统去处理的.示例代码如下: <!-- 订阅开机结束广播 --> <receiver android:name=".receiver.BootCompleteReceiver" > <intent-

Android基础笔记(九)- 广播

广播的概念 案例-监听短信到来并解析短信内容 案例-拦截外拨电话并设置区号 案例-SD卡状态监听 介绍一些常用的广播 发送自定义广播 有序广播和无序广播 启程!!! 广播的概念 广播的种类: 无序广播(Normal broadcasts),类似于日常使用的WIFI,由一个广播者发出信号,可以有很多接收者同时接收,并且信号无法被中断和篡改: 有序广播(Ordered broadcasts),可以有最终的接收者,并存在信号接收的优先级: 定义广播接收者的步骤: ①定义一个类,继承BroadcastR

【Java】检查型异常和非检查型异常

检查型异常(CheckedException)在Java中所有不是RuntimeException派生的Exception都是检查型异常.当函数中存在抛出检查型异常的操作时该函数的函数声明中必须包含throws语句.调用改函数的函数也必须对该异常进行处理,如不进行处理则必须在调用函数上声明throws语句. 检查型异常是JAVA首创的,在编译期对异常的处理有强制性的要求.在JDK代码中大量的异常属于检查型异常,包括IOException,SQLException等等. 非检查型异常(Unchec

检查型异常和非检查型异常

对于因为编程错误而导致的异常,或者是不能期望程序捕获的异常(解除引用一个空指针,数组越界,除零,等等),为了使开发人员免于处理这些异常,一些异常被命名为非检查型异常(即那些继承自 RuntimeException 的异常)并且不需要进行声明. Checked Exception和Unchecked Exception的几点不同之处 方法签名是否需要声明exception 调用该方法时是否需要捕获exception exception产生的时候JVM控制程序的状态 Sun 的"The JavaTu

oracle 非数字型转数字型

原文:oracle 非数字型转数字型 oracle中如果一个字段内容不全是数字型 可以通过以下方式过滤 to_number(substr(translate(a.vital_signs_cvalues, '9876543210.' || a.vital_signs_cvalues, '9876543210.'), 1, instr(translate(a.vital_signs_cvalues, '9876543210.' || a.vital_signs_cvalues, '987654321