关于Java代码在应用层获取Android系统属性的使用实例
之前使用native代码的property_get()/property_set()来获取android属性,现在需要改写到java上面,
但是system.getproperty() /system.setproperty()所操作的属性与上面的是不同的东西,而在android.os.build只提供了访问ro属性的方法。
好在google提供了一个隐藏类android.os.systemproperties用来管理属性,其内部实际上也是通过jni调用native的property_get和property_set方法来获得和设置属性。我们不能直接import这个类来使用,但是可以通过java中的反射机制来实现。
get代码如下:
private static method getstringpropmethod = null; private static method getbooleanpropmethod = null; public static string getsystempropstring(final string key, final string defaultvalue) { try { if (getstringpropmethod == null) { getstringpropmethod = class.forname("android.os.systemproperties") .getmethod("get", string.class, string.class); } return (string) getstringpropmethod.invoke(null, key, defaultvalue); } catch (exception e) { log.e(tag, "reflect error: " + e.tostring()); return defaultvalue; } } public static boolean getsystempropboolean(final string key, final boolean defaultvalue) { try { if (getbooleanpropmethod == null) { getbooleanpropmethod = class.forname("android.os.systemproperties") .getmethod("getboolean", string.class, boolean.class); } return (boolean) getbooleanpropmethod.invoke(null, key, defaultvalue); } catch (exception e) { log.e(tag, "reflect error: " + e.tostring()); return defaultvalue; } }
属性名字的意义:
(1)persist.* :以persist开始的属性会在/data/property存一个副本。也就是说,如果程序调property_set设了一个以persist为前缀的属性,系统会在/data/property/*里加一个文件记录这个属性,重启以后这个属性还有。
如果property_set其它属性,因为属性是在内存里存,所以重启后这个属性就没有了。
(2)ro.* :以ro为前缀的属性不能修改。
(3)如果属性名称以“net.”开头,当设置这个属性时,“net.change”属性将会自动设置,以加入到最后修改的属性名。(这是很巧妙的。 netresolve模块的使用这个属性来追踪在net.*属性上的任何变化。)
(4)属性“ ctrl.start ”和“ ctrl.stop ”是用来启动和停止服务。每一项服务必须在/init.rc中定义.系统启动时,与init守护进程将解析init.rc和启动属性服务。一旦收到设置“ ctrl.start ”属性的请求,属性服务将使用该属性值作为服务名找到该服务,启动该服务。这项服务的启动结果将会放入“ init.s.<服务名>“属性中。客户端应用程序可以轮询那个属性值,以确定结果。