海王  
Android为了储存关于全局系统设置的信息,使用了一个系统属性公共缓冲区,这个缓冲区的内容是(属性,值)对的列表,对外提供get和set服务。可以说,属性区域相当于一般应用的配置文件。
属性系统首先得有个固定地址空间,在system/core/init/init.c里调用property_init()函数初始化。在system/core/init目录下有
property_service.c和property_service.h两个文件予以这个属性系统的支持,属性系统使用的存储空间是通过android的内存管理

系统ashmem 来分配的。其中system/core/init/init.c中用到的设置和获取的服务函数(property_set(),property_get())都是

在system/core/initproperty_service.c实现的。至于这两个服务函数的具体有效范围还有待进一步的研究,因为在

 

system/core/libcutils/properties.c 中在不同的情况下分别进行此两个接口的实现,暂时也没有研究其使用。

 


init.c使用的property_get是个包装函数,其实现是调用__system_property_find()函数,这个函数在
bionic/libc/bionic/system_properties.c中实现。

 

并且在init.c中导入了一个很有用的环境变量:ANDROID_PROPERTY_WORKSPACE

这个环境变量也十分特殊,其由文件描述符和大小组成。也正是因为这个环境变量所以在

bionic/libc/bionic/system_properties.c 中才有可能通过__system_properties_init()[此函数被
bionic/libc/bionic/libc_init_common.c的__libc_init_common()调用进行初始化]进行初始化libc中的属性系统地址,才可能正常的通过

 

__system_property_find()获取属性值。
 

 

 

__libc_init_common()被bionic/libc/bionic/libc_init_dynamic.c(或者libc_init_static.c)调用,且其被调用函数的说明如下:

 

 

 

代码
/* We flag the __libc_preinit function as a constructor to ensure
 * that its address is listed in libc.so's .init_array section.
 * This ensures that the function is called by the dynamic linker
 * as soon as the shared library is loaded.
 
*/
void __attribute__((constructor)) __libc_prenit(void);

void __libc_prenit(void)
{
...
__libc_init_common(elfdata);
...
}


 

getprop

setprop

 

 

posted on 2011-01-31 00:46  海王  阅读(2123)  评论(0编辑  收藏  举报