【Android】四大组件归纳总结
随着学习持续更新
四大组件均可使用android:process="name"在Manifest中声明成独立进程
Activity
生命周期

4种启动模式
Android使用回退栈来管理Activity实例。当前显示的Activity在栈顶,当点击后退或返回时,栈顶的Activity出栈。
可以指定Activity的启动模式来避免重复创建同一Activity
在AndroidManifest.xml中声明Activity的启动模式
<activity android:name=".MyActivity"
android:lauchMode="singleTask"></activity>
standard
默认的启动模式,允许Activity被多次实例化,一个任务栈中会有多个Activity实例
singleTop
处于栈顶的Activity会被重用,若不在栈顶则会被重新创建。重用时会调用原来实例的
onNewIntent()函数singleTask(常用)
一个任务栈只允许存在一个Activity实例,当
startActivity()时,若该Activity在栈内,则会将该Activity上的所有Activity销毁,使该Activity处于栈顶,并调用onNewIntent()方法singleInstance
一个Activity在独立的任务中开启,保证在系统中只有一个实例,所有的
startActivity()都会重用该实例,并回调onNewIntent()方法
两个Activity互相切换时的生命周期
A:onCreate->onStart->onResume
这是在A中启动B活动,生命周期如下:
A: onPause
B: onCreate->onStart->onResume
A: onStop
从B中返回A活动时
B: onPause
A: onRestart->onStart->onResume
B: onStop->onDestroy
Service
当程序进入后台运行时,所需要做的操作可以通过Service实现。
在任何位置调用startService()启动服务。
每个服务只存在一个实例,每次调用startService()时会回调onStartCommand();只需要调用一次stopService()或stopSelf()函数,服务会被停止。
普通Service运行在UI线程,若需要执行耗时操作需要新开线程。
生命周期
onCreate()onStartCommand(intent, flags, startId)有三种返回值
- START_STICKY:当服务因内存不足被kill掉后,内存空闲时会尝试重建服务,重建成功则回调
onStartCommand(),这是传入的intent为null - START_NOT_STICKY:当Service因内存不足而被系统kill后,即使系统内存再次空闲时,系统也不会尝试重新创建此Service
- START_REDELIVER_INTENT:当Service因内存不足而被系统kill后,则会重建服务,并通过传递给服务的最后一个 Intent 调用
onStartCommand(),这个值适用于主动执行应该立即恢复的作业(例如下载文件)的服务
- START_STICKY:当服务因内存不足被kill掉后,内存空闲时会尝试重建服务,重建成功则回调
onDestroy()调用
stopService()或stopSelf()
IntentService
重写onHandleIntent()函数,在函数中完成耗时操作。IntentService会自动将操作执行在子线程中,并在完成时调用stopSelf()自我销毁
public class MyIntentService extends IntentService {
@Override
protected void onHandleIntent(Intent intent) {
...
}
}
Binder(与服务连接)
当服务仅限本地应用使用,不需要跨进程工作,则可以实现自有的Binder类,让客户端通过该类直接访问服务中的公共方法。
首先需要创建ServiceConnection对象,代表与服务的连接,有两个方法
onServiceConnected(name, serivce)系统会调用该方法传递服务的
onBind()方法返回的IBinder, 通过该对象可以调用获取到Service的实例对象,进而调用服务端的公共方法。onServiceDisconnected(name)系统与服务意外中断时调用,unBind不会调用该方法
调用bindService(intent, ServiceConnection, flag)绑定相关服务,flag指绑定时是否自动创建Service,0表示不创建;BIND_AUTO_CREATE表示自动创建。
调用unbindService(ServiceConnection)
当最后一个客户端与服务取消绑定时,系统会将服务销毁
前台服务
startForeground(int id, Notification notification)将当前服务设成前台服务,id参数为唯一标识通知的整型数,不得为0
stopForeground(boolean removeNotification)
Android8.0后需要开启前台服务要在Activity中startForegroundService(i),且之后Service要在5s内调用startForeground()才能成功创建前台服务
如何保证Service不被杀死
内存资源不足
- 将
onStartCommand()返回值设成START_STICKY或START_REDELIVER_INTENT,这样内存组后也会恢复服务 - 将服务设成前台服务,具备较高优先级
- 将
用户手动干预
如果不是force stop则会调用生命周期中的
onDestroy()方法,可以在方法中发送广播重启服务。完备一些的话就启动两个服务,相互监听,相互重启。
Broadcast
组成:发送广播的Broadcast,接受广播的BroadcastReceiver和传递消息的Intent。
类型:普通广播、有序广播、本地广播(LocalBroadcast)、Sticky广播
静态广播与动态广播
广播可分为静态注册和动态注册两种形式
静态注册
在Manifest.xml中声明静态广播
<receiver android:name=".MyReceiver">
<intent-filter android:priority=1000>
<action android:name="com.broadcast"
</intent-filter>
</receiver>
动态注册
可以在
onCreate的时候注册MyBroadcastReceiver receiver = new MyBroadcastReceiver();
IntentFilter filter = new IntentFilter("my.action");
context.registerReceiver(receiver, filter);
在
onDestroy的时候注销unregisterReceiver(receiver);
静态广播与动态广播的区别
- 静态广播在activity注销的时候也能够继续接收;动态广播在APP退出后就无法接收了
- 动态广播在相同Priority下优先级比静态广播高
普通广播
异步广播,调用sendBroadcast(new Intent(ACTION))来发出广播
定义广播接收器
public class MyBroadcastReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
...
}
}
在AndroidManifest.xml中注册:
<receiver android:name=".broadcast.MyBroadcastReceiver">
<intent-filter>
<action android:name=".."/>
</intent-filter>
</receiver>
动态注册接收器:
registerReceiver(new MyBroadcastReceiver(), new IntentFilter(MY_ACTION));
有序广播
发送出去的广播被广播的接收者按照先后顺序接收
接收的顺序排序
- 按照Priority属性值从大到小
- Priority相同则动态注册广播优先
本地广播
只限于应用的广播
使用LocalBroadcastManager.getInstance(context)来使用关于广播的操作函数:
registerReceiver(receiver, intentFilter)unregisterReceiver(receiver)sendBroadcast(new Intent(INTENT_NAME))sendBroadcastSync(new Intent())
注册本地广播
mLocalBroadcastManager = LocalBroadcastManager.getInstance(this);
mReceiver = new MyBroadcastReceiver();
IntentFilter filter = new IntentFilter();
filter.addAction(ACTION_MY_TYPE);
mLocalBroadcastManager.registerReceiver(mReceiver,filter);
需要在onDestory()的中进行注销:
mLocalBroadcastManager.unregisterReceiver(mReceiver)
ContentProvider
ContentProvider可以将应用中的数据共享给其他应用访问,其他应用可以通过ContentProvider对应用中的数据进行增删改查。
也可以进行进程间数据的交互和共享,跨进程通信。
【Android】四大组件归纳总结的更多相关文章
- Android 四大组件之" ContentProvider "
前言 ContentProvider作为Android的四大组件之一,是属于需要掌握的基础知识,可能在我们的应用中,对于Activity和Service这两个组件用的很常见,了解的也很多,但是对Con ...
- Android四大组件之一“广播”
前言 Android四大组件重要性已经不言而喻了,今天谈谈的是Android中的广播机制.在我们上学的时候,每个班级的教室里都会装有一个喇叭,这些喇叭都是接入到学校的广播室的,一旦有什么重要的通知,就 ...
- Android 四大组件 与 MVC 架构模式
作为一个刚从JAVA转过来的Android程序员总会思考android MVC是什么样的? 首先,我们必须得说Android追寻着MVC架构,那就得先说一下MVC是个啥东西! 总体而来说MVC不能说是 ...
- android四大组件(简单总结)
activity 一个Activity通常就是一个单独的屏幕(窗口) Activity之间通过Intent进行通信 android应用中每一个Activity都必须要在AndroidManifest. ...
- android四大组件之Broadcast
广播的概念 现实中:我们常常使用电台通过发送广播发布消息,买个收音机,就能收听 Android:系统在产生某个事件时发送广播,应用程序使用广播接收者接收这个广播,就知道系统产生了什么事件.Androi ...
- Android 四大组件之再论service
service常见的有2种方式,本地service以及remote service. 这2种的生命周期,同activity的通信方式等,都不相同. 关于这2种service如何使用,这里不做介绍,只是 ...
- Android四大组件及activity的四大启动模式
Android四大组件 1. 广播接收者的两种类型: (1)系统广播接收者,就是继承BroadcastReceiver这个类,然后还要在清单文件中注册,注册之后给他一个action.当系统发生了这个a ...
- Android成长日记-Android四大组件之Service组件的学习
1.什么是Service? Service是Android四大组件中与Activity最相似的组件,它们都代表可执行的程序,Service与Activity的区别在于:Service一直在后台运行,它 ...
- Android四大组件之Activity(活动)及其布局的创建与加载布局
Android四大组件之Activity(活动)及其布局的创建与加载布局 什么是Activity ? 活动(Activity)是包含用户界面的组件,主要用于和用户进行交互的,一个应用程序中可以包含零个 ...
- Android四大组件之——Activity的生命周期(图文详解)
转载请在文章开头处注明本博客网址:http://www.cnblogs.com/JohnTsai 联系方式:JohnTsai.Work@gmail.com [Andro ...
随机推荐
- Java多线程基础详解
基础概念进程进程是操作系统结构的基础:是一次程序的执行:是一个程序及其数据在处理机上顺序执行时所发生的活动.操作系统中,几乎所有运行中的任务对应一条进程(Process).一个程序进入内存运行,即变成 ...
- deeplearning.ai 改善深层神经网络 week3 超参数调试、Batch Normalization和程序框架
这一周的主体是调参. 1. 超参数:No. 1最重要,No. 2其次,No. 3其次次. No. 1学习率α:最重要的参数.在log取值空间随机采样.例如取值范围是[0.001, 1],r = -4* ...
- FPGA的存储方式大全
好的时序是通过该严密的逻辑来实现的.http://blog.csdn.net/i13919135998/article/details/52117053介绍的非常好 有RAM(随机存储器可读可写)RO ...
- 如何模拟ip
展开全部回答查看 https://segmentfault.com/q/1010000002990136 模拟国外ip https://gtmetrix.com/ 登录后才可以切换模拟的地区
- Oracle 11g 静默安装过程(centos7)
开启机器,本次实例分配的ip是:192.168.3.197(Xshell ssh连接) 2 安装unzip 工具.vim编辑器(个人习惯,vi也可以) 3 在/etc/hosts文件中添加本机IP跟主 ...
- t分布|F分布|点估计与区间估计联系|
应用统计学 推断统计需要样本形容总体,就要有统计量.注意必须总体是正态分布,否则统计量的分布不能得到.卡方分布和t分布只要样本大于30都近似于正态分布. t分布和F分布推导及应用(图): 总体比例是π ...
- Win32 计时器
计时器精确吗? 计时器并不精确.有两个原因: 原因一:Windows计时器是硬件和ROM BIOS架构下之计时器一种相对简单的扩充.回到Windows以前的MS-DOS程序写作环境下,应用程式能够通过 ...
- SpringMVC学习笔记七:SpringMVC的数据验证
SpringMVC支持JSR(Java Specification Requests, Java规范提案)303-Bean Validation数据验证规范,该规范的实现者很多,其中较常用的是 Hib ...
- Servlet与JSP概念理解
Servlet是用Java编写的服务端程序.需要部署到servlet容器上才能运行,tomcat 就是一个servlet容器. 1.Servlet的生命周期 客户端请求该 Servlet --> ...
- 在腾讯云服务器上安装JDK+Tomcat并启动tomcat
由于Java web项目需要使用到tomcat所以决定在腾讯云服务器(centos7.X)上安装JDK和tomcat,来部署我们的项目. 准备工具: 云服务器:centos7.x+ 本地连接服务器:X ...