【Android】四大组件归纳总结

简介:

【Android】四大组件归纳总结
随着学习持续更新

四大组件均可使用android:process="name"在Manifest中声明成独立进程

Activity#
生命周期#

4种启动模式#
Android使用回退栈来管理Activity实例。当前显示的Activity在栈顶,当点击后退或返回时,栈顶的Activity出栈。

可以指定Activity的启动模式来避免重复创建同一Activity

在AndroidManifest.xml中声明Activity的启动模式

Copy

      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#
https://blog.csdn.net/javazejian/article/details/52709857

当程序进入后台运行时,所需要做的操作可以通过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(),这个值适用于主动执行应该立即恢复的作业(例如下载文件)的服务
onDestroy()
调用stopService()或stopSelf()

IntentService#
重写onHandleIntent()函数,在函数中完成耗时操作。IntentService会自动将操作执行在子线程中,并在完成时调用stopSelf()自我销毁

Copy
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#
https://www.jianshu.com/p/ca3d87a4cdf3

组成:发送广播的Broadcast,接受广播的BroadcastReceiver和传递消息的Intent。

类型:普通广播、有序广播、本地广播(LocalBroadcast)、Sticky广播

静态广播与动态广播#
广播可分为静态注册和动态注册两种形式

静态注册
在Manifest.xml中声明静态广播

Copy

<intent-filter android:priority=1000>
    <action android:name="com.broadcast"
</intent-filter>


动态注册
可以在onCreate的时候注册

Copy
MyBroadcastReceiver receiver = new MyBroadcastReceiver();
IntentFilter filter = new IntentFilter("my.action");
context.registerReceiver(receiver, filter);
在onDestroy的时候注销

Copy
unregisterReceiver(receiver);
静态广播与动态广播的区别
静态广播在activity注销的时候也能够继续接收;动态广播在APP退出后就无法接收了
动态广播在相同Priority下优先级比静态广播高
普通广播#
异步广播,调用sendBroadcast(new Intent(ACTION))来发出广播

定义广播接收器

Copy
public class MyBroadcastReceiver extends BroadcastReceiver {

@Override
public void onReceive(Context context, Intent intent) {
    ...
}

}
在AndroidManifest.xml中注册:

Copy

<intent-filter>
    <action android:name=".."/>
</intent-filter>


动态注册接收器:

Copy
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())
注册本地广播

Copy
mLocalBroadcastManager = LocalBroadcastManager.getInstance(this);
mReceiver = new MyBroadcastReceiver();
IntentFilter filter = new IntentFilter();
filter.addAction(ACTION_MY_TYPE);
mLocalBroadcastManager.registerReceiver(mReceiver,filter);
需要在onDestory()的中进行注销:

Copy
mLocalBroadcastManager.unregisterReceiver(mReceiver)
ContentProvider#
ContentProvider可以将应用中的数据共享给其他应用访问,其他应用可以通过ContentProvider对应用中的数据进行增删改查。

也可以进行进程间数据的交互和共享,跨进程通信。

作者: y4ngyy

出处:https://www.cnblogs.com/y4ngyy/p/12496745.html

相关文章
|
搜索推荐 Android开发 开发者
探索安卓开发中的自定义视图:打造个性化UI组件
【10月更文挑战第39天】在安卓开发的世界中,自定义视图是实现独特界面设计的关键。本文将引导你理解自定义视图的概念、创建流程,以及如何通过它们增强应用的用户体验。我们将从基础出发,逐步深入,最终让你能够自信地设计和实现专属的UI组件。
|
Android开发 算法 架构师
android的基础ui组件,这些知识点你会吗
android的基础ui组件,这些知识点你会吗
android的基础ui组件,这些知识点你会吗
|
存储 Android开发 开发者
深入理解安卓应用开发的核心组件
【10月更文挑战第8天】探索Android应用开发的精髓,本文带你了解安卓核心组件的奥秘,包括Activity、Service、BroadcastReceiver和ContentProvider。我们将通过代码示例,揭示这些组件如何协同工作,构建出功能强大且响应迅速的应用程序。无论你是初学者还是资深开发者,这篇文章都将为你提供新的视角和深度知识。
|
数据可视化 Android开发 开发者
安卓应用开发中的自定义View组件
【10月更文挑战第5天】在安卓应用开发中,自定义View组件是提升用户交互体验的利器。本篇将深入探讨如何从零开始创建自定义View,包括设计理念、实现步骤以及性能优化技巧,帮助开发者打造流畅且富有创意的用户界面。
457 0
|
XML 搜索推荐 前端开发
安卓开发中的自定义视图:打造个性化UI组件
在安卓应用开发中,自定义视图是一种强大的工具,它允许开发者创造独一无二的用户界面元素,从而提升应用的外观和用户体验。本文将通过一个简单的自定义视图示例,引导你了解如何在安卓项目中实现自定义组件,并探讨其背后的技术原理。我们将从基础的View类讲起,逐步深入到绘图、事件处理以及性能优化等方面。无论你是初学者还是有经验的开发者,这篇文章都将为你提供有价值的见解和技巧。
|
测试技术 数据库 Android开发
深入解析Android架构组件——Jetpack的使用与实践
本文旨在探讨谷歌推出的Android架构组件——Jetpack,在现代Android开发中的应用。Jetpack作为一系列库和工具的集合,旨在帮助开发者更轻松地编写出健壮、可维护且性能优异的应用。通过详细解析各个组件如Lifecycle、ViewModel、LiveData等,我们将了解其原理和使用场景,并结合实例展示如何在实际项目中应用这些组件,提升开发效率和应用质量。
589 6
|
XML 前端开发 Java
安卓应用开发中的自定义View组件
【10月更文挑战第5天】自定义View是安卓应用开发的一块基石,它为开发者提供了无限的可能。通过掌握其原理和实现方法,可以创造出既美观又实用的用户界面。本文将引导你了解自定义View的创建过程,包括绘制技巧、事件处理以及性能优化等关键步骤。
|
存储 开发框架 数据可视化
深入解析Android应用开发中的四大核心组件
本文将探讨Android开发中的四大核心组件——Activity、Service、BroadcastReceiver和ContentProvider。我们将深入了解每个组件的定义、作用、使用方法及它们之间的交互方式,以帮助开发者更好地理解和应用这些组件,提升Android应用开发的能力和效率。
1656 5
|
缓存 搜索推荐 Android开发
安卓应用开发中的自定义View组件实践
【9月更文挑战第10天】在安卓开发领域,自定义View是提升用户体验和实现界面个性化的重要手段。本文将通过一个实际案例,展示如何在安卓项目中创建和使用自定义View组件,包括设计思路、实现步骤以及可能遇到的问题和解决方案。文章不仅提供了代码示例,还深入探讨了自定义View的性能优化技巧,旨在帮助开发者更好地掌握这一技能。
|
存储 搜索推荐 Java
探索安卓开发中的自定义视图:打造个性化UI组件Java中的异常处理:从基础到高级
【8月更文挑战第29天】在安卓应用的海洋中,一个独特的用户界面(UI)能让应用脱颖而出。自定义视图是实现这一目标的强大工具。本文将通过一个简单的自定义计数器视图示例,展示如何从零开始创建一个具有独特风格和功能的安卓UI组件,并讨论在此过程中涉及的设计原则、性能优化和兼容性问题。准备好让你的应用与众不同了吗?让我们开始吧!

热门文章

最新文章