《Android SDK Document 框架导读的翻译和注解》系列的文章将对Android应用程序的架构做一个基本的介绍,本文源于Android SDK ducument的第一个部分,描绘了Android 应用程序系统的骨架,因此,这部分对理解Android系统是最有帮助的。在翻译的时候,增加本人对Android的理解和评价。请指正。
本文介绍Android架构及SDK 的API框架
Android应用程序基础:
Android 应用程序由Java编写。被编译好的java文件,跟数据以及资源文件一起,被aapt tool
打包成一个单独的apk文件。
从很多方面看来,一个.apk文件代表的应用程序生存在自己的世界中:
1: 默认情况下:所有的应用程序在各自的Linux进程中运行。 【ostrichmyself: 也就是说每个Application对应一个进程】
2: 每个进程有自己的VM,因此运行的代码和其它所有的应用程序是隔离的。【ostrichmyself: 应该是指每个进程都是一个vm】
3: 默认情况下:每个应用程序分配给一个Linux User ID. Linux的权限设定,使得可执行程序文件只能够被这个User和这个应用程序可见。——当然,也有方法可以将这些应用程序暴露给其它的应用程序。【ostrichmyself: 后面马上提到,应用程序之间在某些情况下,需要暴露给对方,这个时候需要做些设置, 大部分情况, 我觉得都是很多应用程序,对应了同一个User ID】
将两个应用程序拥有同一个UserID,然后让他们能被对方可见,这种安排是可能的。为了节省系统资源, 具有相同的User ID的应用程序,可以安排在同一个Linux进程中运行,并共享同一个VM。【ostrichmyself: 注意,大部分的情况是默认情况,这里只是说特殊情况下,可以这么做,可以这样设置。】
【ostrichmyself: Linux操作系统的本来思路是: 同一个用户的维度上,每个应用程序,应该都有一个Linux进程,每个Linux进程对应一个VM, 从而有多个VM. 但手持设备在特殊情况下的安排是: 多个APK使用同一个进程和同一个VM, 但这样的情况不常见】
应用程序涉及的各种组件:
Android系统的一个主要特征是,一个应用程序能利用来自其他应用程序的元素(前提是被其它应用程序所允许)。 举例说明:如果你的应用程序需要将一组图片滚动显示,这时,如果另外一个应用程序提供了一个滚轮,并且允许其它程序访问。这个时候,你就不需要开发了,而是直接调用就OK。【ostrichmyself:这个绝对是Eclipse RCP插件平台的思想,Android的所有应用程序,都当做一个Plugin了。由配置文件xml管理这访问权限,因此Android应用程序管理中有N多前台看不到的应用程序, 实质上,借助Eclipse RCP的概念,能启动的程序,可以称之为RCP程序,只提供组件服务的,不能直接运行的程序,叫做Plug-in. 并且一个RCP程序,都可以当作Plug-in看待,Android就是这种情况。】
对于上述这个功能【能调用其它application的代码片段】的实现,Android系统必须有这样一个能力,即它能够启用任意一个当前需要的其它应用程序进程,只要是这个进程中有部分代码需要被当前的Application用到,并且将这部分的代码初始化成Java对象。与其他系统的应用程序不同, Android应用程序中,没有单一的启动入口,如main()函数。相反,他们拥有几个核心的组件让系统初始化,并在需要的时候运行。这类组件可以分为四类: Activity, Services,Brodcast receivers, Content provider.
关于一个Application调用其它Application时, 进程关系的情况, 可以在下面的博客中看到更详细的说明:
Android 组件复用和进程关系
后续文章将谈到具体的四个组件, 请继续关注