打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
【转】关android的property机制-- 原理

有关android的property机制  

今天跟璋儿讨论到系统配置的问题。最常见的做法是由一个进程来维护这些配置,进行读写。其它的进程如果需要set/get某一配置项,需要通过socket发送消息到管理进程。

我想到了android的property机制。其实property就是name&value对,与常见系统中的配置项没有差异。在android系统中,大量使用了property_set和property_get,用来设置和获取某一property。下面来分析一下。

property_set/property_get位于libcutils.so库。任何进程若要调用这两个函数,需要链接libcutils.so。

libcutils.so调用到了__system_property_set和__system_property_get函数,这两个函数位于bionic库中,源代码文件为bionic/libc/bionic/system_properties.c,生成的库文件为libc_common.so。

对于set和get,分别会创建socket,发送消息到服务端。服务端位于init进程中,有一个property_service进程专门负责这个。该service读取socket消息,进行set和get的处理。property_service代码位于system/core/init/property_service.c

在system_properties.c和property_service.c中都用到了共享内存(用mmap实现),这里我开始有些搞不懂:如果用socket机制的话,只需要管理进程来维护内存即可,客户端不许要访问该内存,干嘛要用共享内存呢?

原来,android这样做是为了效率考虑。在system_properties.c的get调用中,可以通过只读方式访问共享内存,直接获取配置。当然了,为了保证get的时候别人不在set,避免读写冲突,get时需要等待一个信号量。对于set,system_properties.c会通过socket发送消息到service端处理,service端增加或者更新property后会wake该信号量。service端以读写方式打开共享内存。

为什么要这样设计呢?因为系统中由大量的get调用,get可以直接访问共享内存,所以访问更快。对于set,需要交给服务端处理,这样开销比较大,因为用到了socket,但因为set调用相对较少,所以问题也不严重。另为,android系统由以ctl打头的property,这种property比较特殊,可以控制服务的运行和停止,将这些控制放在service(即init进程)也就理所当然了!

附上一个框图:

 
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
云中漫步 ? (翻译)Android属性系统
Android面试——多进程通信,Binder机制和AIDL
Android 的系统属性(SystemProperties)分析 | Bob's Blo...
Android中的Binder机制的简要理解
Android相关面试题
Android剖析和运行机制
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服