Android应用通常由一个或者多个组件组成,这些组件包括Activity,Service, BroardcastReceiver, ContentProvider等
Activity是Android应用中负责与用户交互的组件,为用户提供可视化的用户界面,如果应用需要多个用户界面,那么这个应用就需要多个Activity,多个Activity一起组成Activity栈,当前活动的Activity位于栈顶。Activity组件需要继承Activity基类。
Service与Activity的地位并列,也是一个单独的Android组件,两者的区别在于:Service通常后台运行,不需要与用户交互,也没有图形用户界面。Service组件拥有自己的独立生命周期,通常为其他组件提供后台服务或者监控其他组件的运行状态,Service需要继承Service基类。
BroardcastReceiver是Android应用中的一个重要组件。从代码的角度看BroardcastReceiver非常类似与事件编程中的监听器,只是其监听的对象是Android应用中的其他组件。实现BroardcastReceiver比较简单,只需要继承BroardcastReceiver基类,并重写onReceiver方法即可。当其他组件通过sendBroardcast、sendStickyBroardcast或者sendOrderedBroardcast方法发送广播消息的时候,如果该BroardcastReceiver也对该消息感兴趣,BroardcastReceiver的onReceive方法将会被触发。
ContentProvider
对于Android应用而言,他们必须相对独立,各自运行在自己的Dalvik虚拟机实例中,如果不同的应用之间需要实现实时的数据交换。Android系统为跨应用的数据交换提供了一个标准:ContentProvider。当用户实现自己的ContentProvider时,需要实现以下抽象方法:
Insert:向ContentProvider插入数据
Delete:删除ContentProvider中指定的数据
Update:更新ContentProvider中指定的数据
Query:从ContentProvider中查询数据
通常与ContentProvider结合使用的是ContentResolver,一个应用使用ContentProvider暴露自己的数据,而另外一个应用使用ContentResolver来访问数据。
Intent和IntentFilter
严格来说,Intent并不是Android的组件,但是其作用非常大,它是Android中不同组件之间通信的载体。Intent可以启动应用中的另外一个Activity,也可以启动一个Service组件,还可以发送一条广播来触发系统中的BroardcastReceiver。也就是说Activity,Service,BroardcastReceiver三个组件之间的通信都是通过Intent作为载体的,只是不同组件使用Intent的机制策略稍有不同。