Android反射机制:手把手教你实现反射

什么是反射机制?

      JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意一个方法和属性;这种动态获取的信息以及动态调用对象的方法的功能称为java语言的反射机制(注意关键词:运行状态)换句话说,Java程序可以加载一个运行时才得知名称的class,获悉其完整构造(但不包括methods定义),并生成其对象实体、或对其fields设值、或唤起其methods

反射机制主要提供的功能

  • 在运行时判断任意一个对象所属的类;
  • 在运行时构造任意一个类的对象;
  • 在运行时判断任意一个类所具有的成员变量和方法;
  • 在运行时调用任意一个对象的方法;

java Reflection API简介

  • Class类:代表一个类,位于java.lang包下
  • Field类:代表类的成员变量(成员变量也称为类的属性)
  • Method类:代表类的方法
  • Constructor类:代表类的构造方法
  • Array类:提供了动态创建数组,以及访问数组的元素的静态方法

java中的Class介绍

       Class 类十分特殊,它没有共有的构造方法,被jvm调用的(简单的理解:new对象或者被类加载器加载的时候),在Java中,每个class都有一个相应的Class对象。也就是说,当我们编写一个类,编译完成后,在生成的.class文件中,就会产生一个Class对象,用于表示这个类的类型信息。

java中的Class三种获取方式

  • 利用对象调用getClass()方法获取该对象的Class实例;
  • 使用Class类的静态方法forName(),用类的名字获取一个Class实例 ;
  • 运用.class的方式来获取Class实例,对于基本数据类型的封装类,还可以采用.TYPE来获取相对应的基本数据类型的Class实例;

       说明:在运行期间,如果我们要产生某个类的对象,Java虚拟机(JVM)会检查该类型的Class对象是否已被加载。如果没有被加载,JVM会根据类的名称找到.class文件并加载它。一旦某个类型的Class对象已被加载到内存,就可以用它来产生该类型的所有对象。

 
  1.     //方式一

  2.     Person person = new Person();

  3.     Class<? extends Person> personClazz01 = person.getClass();

  4.  
  5.     //方式二

  6.     try {

  7.         Class<?> personClazz02 = Class.forName("Person");

  8.     } catch (ClassNotFoundException e) {

  9.         e.printStackTrace();

  10.     }

  11.  
  12.     //方式三

  13.     Class<? extends Person> personClazz03 = Person.class;

 

 

 

java中的Class中一些重要的方法

  • public Annotation[] getAnnotations () 获取这个类中所有注解

  • getClassLoader() 获取加载这个类的类加载器

  • getDeclaredMethods() 获取这个类中的所有方法

  • getReturnType() 获取方法的返回类型

  • getParameterTypes() 获取方法的传入参数类型

  • isAnnotation() 测试这类是否是一个注解类

  • getDeclaredConstructors() 获取所有的构造方法

  • getDeclaredMethod(String name, Class… parameterTypes) 获取指定的构造方法(参数:参数类型.class)

  • getSuperclass() 获取这个类的父类

  • getInterfaces() 获取这个类实现的所有接口

  • getFields() 获取这个类中所有被public修饰的成员变量

  • getField(String name) 获取指定名字的被public修饰的成员变量

  • newInstance() 返回此Class所表示的类,通过调用默认的(即无参数)构造函数创建的一个新实例

等等方法

如何通过反射获取私有成员变量和私有方法

Person类

 
  1. /**

  2. * Created by yuanyc on 2016/1/28.

  3. */

  4. public class Person {

  5. private String name = "zhangsan";

  6. private String age;

  7.  
  8. public String getName() {

  9.     return name;

  10. }

  11.  
  12. public void setName(String name) {

  13.     this.name = name;

  14. }

  15. }  

  16.  
  17.  
  18.     Person person = new Person();

  19.     //打印没有改变属性之前的name值

  20.     System.out.println("before:" + getPrivateValue(person, "name"));

  21.     person.setName("lisi");

  22.     //打印修改之后的name值

  23.     System.out.println("after:" + getPrivateValue(person, "name"));

  24.  
  25.  
  26.  
  27. /**

  28. * 通过反射获取私有的成员变量

  29. *

  30. * @param person

  31. * @return

  32. */

  33. private Object getPrivateValue(Person person, String fieldName) {

  34.  
  35.     try {

  36.         Field field = person.getClass().getDeclaredField(fieldName);

  37.         // 参数值为true,打开禁用访问控制检查

  38.         //setAccessible(true) 并不是将方法的访问权限改成了public,而是取消java的权限控制检查。

  39.         //所以即使是public方法,其accessible 属相默认也是false

  40.         field.setAccessible(true);

  41.         return field.get(person);

  42.     } catch (Exception e) {

  43.         e.printStackTrace();

  44.     }

  45.     return null;

  46. }  

 

 

 

运行结果:
yyc_12yyc_12

获取私有方法的方式类似获取私有成员变量的方式 
Filed类,Method类等详细查看开发者文档:
http://developer.android.com/intl/zh-cn/reference/java/lang/reflect/Field.html

案例演示反射

Person类

 
  1. /**

  2. * kaivens

  3. */

  4. public class Person {

  5. private int age;

  6. private String name;

  7. public Person(){

  8.  
  9. }

  10. public Person(int age, String name){

  11.     this.age = age;

  12.     this.name = name;

  13. }

  14.  
  15. public int getAge() {

  16.     return age;

  17. }

  18. public void setAge(int age) {

  19.     this.age = age;

  20. }

  21. public String getName() {

  22.     return name;

  23. }

  24. public void setName(String name) {

  25.     this.name = name;

  26. }

  27.  
  28. }  

SuperPerson类

 
  1. /**

  2. * kaivens

  3. */

  4. public class SuperPerson extends Person implements Smoke.Smoking{

  5. private boolean isMan;

  6.  
  7. public void fly()

  8. {

  9.     System.out.println("走你~~");

  10. }

  11.  
  12. public boolean isMan() {

  13.     return isMan;

  14. }

  15. public void setMan(boolean iaMan) {

  16.     isMan = iaMan;

  17. }

  18. @Override

  19. public void smoke(int count) {

  20.  
  21. }

  22. }  

 

 

 

Smoke接口类

 
  1. /**

  2. * kaivens

  3. */

  4. public class Smoke {

  5. public interface Smoking {

  6.     public void smoke(int count);

  7. }

  8. }  

 

 

 

MainActivity类

 
  1. public class MainActivity extends Activity {

  2.  
  3.  
  4. @Override

  5. protected void onCreate(Bundle savedInstanceState) {

  6.     super.onCreate(savedInstanceState);

  7.     setContentView(R.layout.activity_main);

  8.     Tests();

  9. }

  10.  
  11. private void Tests() {

  12.     try {

  13.         //通过Java反射机制得到类的包名和类名

  14.         Test1();

  15.         System.out.println("===============================================");

  16.  
  17.         //验证所有的类都是Class类的实例对象

  18.         Test2();

  19.         System.out.println("===============================================");

  20.  
  21.         //通过Java反射机制,用Class 创建类对象[这也就是反射存在的意义所在],无参构造

  22.         Test3();

  23.         System.out.println("===============================================");

  24.  
  25.         //通过Java反射机制得到一个类的构造函数,并实现构造带参实例对象

  26.         Test4();

  27.         System.out.println("===============================================");

  28.  
  29.         //通过Java反射机制操作成员变量, set 和 get

  30.         Test5();

  31.         System.out.println("===============================================");

  32.  
  33.         //通过Java反射机制得到类的一些属性: 继承的接口,父类,函数信息,成员信息,类型等

  34.         Test6();

  35.         System.out.println("===============================================");

  36.  
  37.         //通过Java反射机制调用类中方法

  38.         Test7();

  39.         System.out.println("===============================================");

  40.  
  41.         //通过Java反射机制获得类加载器

  42.         Test8();

  43.         System.out.println("===============================================");

  44.     } catch (Exception e) {

  45.         e.printStackTrace();

  46.     }

  47. }

  48.  
  49. /**

  50. * Demo1: 通过Java反射机制得到类的包名和类名

  51. */

  52. public static void Test1() {

  53.     Person person = new Person();

  54.     System.out.println("Test1: 包名: " + person.getClass().getPackage().getName() + "," + "完整类名: " + person.getClass().getName());

  55. }

  56.  
  57. /**

  58. * Demo2: 验证所有的类都是Class类的实例对象

  59. */

  60. public static void Test2() throws ClassNotFoundException {

  61.     //定义两个类型都未知的Class , 设置初值为null, 看看如何给它们赋值成Person类

  62.     Class<?> class1 = null;

  63.     Class<?> class2 = null;

  64.  
  65.     //写法1, 可能抛出 ClassNotFoundException [多用这个写法]

  66.     class1 = Class.forName("com.tuba.yuanyc.audiomanagerdemo.Person");

  67.     System.out.println("Test2:(写法1) 包名: " + class1.getPackage().getName() + "," + "完整类名: " + class1.getName());

  68.  
  69.     //写法2

  70.     class2 = Person.class;

  71.     System.out.println("Test2:(写法2) 包名: " + class2.getPackage().getName() + "," + "完整类名: " + class2.getName());

  72. }

  73.  
  74. /**

  75. * Demo3: 通过Java反射机制,用Class 创建类对象[这也就是反射存在的意义所在]

  76. */

  77. public static void Test3() throws ClassNotFoundException, InstantiationException, IllegalAccessException {

  78.     Class<?> class1 = null;

  79.     class1 = Class.forName("com.android.reflect.Person");

  80.     //由于这里不能带参数,所以你要实例化的这个类Person,一定要有无参构造函数

  81.     Person person = (Person) class1.newInstance();

  82.     person.setAge(26);

  83.     person.setName("kaiven");

  84.     System.out.println("Test3: " + person.getName() + " : " + person.getAge());

  85. }

  86.  
  87. /**

  88. * Demo4: 通过Java反射机制得到一个类的构造函数,并实现创建带参实例对象

  89. */

  90. public static void Test4() throws ClassNotFoundException, IllegalArgumentException, InstantiationException, IllegalAccessException, InvocationTargetException {

  91.     Class<?> class1 = null;

  92.     Person person1 = null;

  93.     Person person2 = null;

  94.  
  95.     class1 = Class.forName("com.android.reflect.Person");

  96.     //得到一系列构造函数集合

  97.     Constructor<?>[] constructors = class1.getConstructors();

  98.  
  99.     try {

  100.         person1 = (Person) constructors[0].newInstance();

  101.     } catch (InvocationTargetException e) {

  102.         e.printStackTrace();

  103.     }

  104.     person1.setAge(28);

  105.     person1.setName("zhuk");

  106.  
  107.     person2 = (Person) constructors[1].newInstance(29, "zhuk");

  108.  
  109.     System.out.println("Test4: " + person1.getName() + " : " + person1.getAge() + "  ,   " + person2.getName() + " : " + person2.getAge());

  110.  
  111. }

  112.  
  113. /**

  114. * Demo5: 通过Java反射机制操作成员变量, set 和 get

  115. */

  116. public static void Test5() throws IllegalArgumentException, IllegalAccessException, SecurityException, NoSuchFieldException, InstantiationException, ClassNotFoundException {

  117.     Class<?> class1 = null;

  118.     class1 = Class.forName("com.android.reflect.Person");

  119.     Object obj = class1.newInstance();

  120.  
  121.     Field nameField = class1.getDeclaredField("name");

  122.     nameField.setAccessible(true);

  123.     nameField.set(obj, "cyy");

  124.  
  125.     System.out.println("Test5: 修改属性之后得到属性变量的值:" + nameField.get(obj));

  126.  
  127. }

  128.  
  129.  
  130. /**

  131. * Demo6: 通过Java反射机制得到类的一些属性: 继承的接口,父类,函数信息,成员信息,类型等

  132. */

  133. public static void Test6() throws ClassNotFoundException {

  134.     Class<?> class1 = null;

  135.     class1 = Class.forName("com.android.reflect.Person");

  136.  
  137.     //取得父类名称

  138.     Class<?> superClass = class1.getSuperclass();

  139.     System.out.println("Test6:  SuperMan类的父类名: " + superClass.getName());

  140.  
  141.     System.out.println("===============================================");

  142.  
  143.  
  144.     Field[] fields = class1.getDeclaredFields();

  145.     for (int i = 0; i < fields.length; i++) {

  146.         System.out.println("类中的成员: " + fields[i]);

  147.     }

  148.     System.out.println("===============================================");

  149.  
  150.  
  151.     //取得类方法

  152.     Method[] methods = class1.getDeclaredMethods();

  153.     for (int i = 0; i < methods.length; i++) {

  154.         System.out.println("Test6,取得SuperMan类的方法:");

  155.         System.out.println("函数名:" + methods[i].getName());

  156.         System.out.println("函数返回类型:" + methods[i].getReturnType());

  157.         System.out.println("函数访问修饰符:" + Modifier.toString(methods[i].getModifiers()));

  158.         System.out.println("函数代码写法: " + methods[i]);

  159.     }

  160.  
  161.     System.out.println("===============================================");

  162.  
  163.     Class<?> interfaces[] = class1.getInterfaces();

  164.     for (int i = 0; i < interfaces.length; i++) {

  165.         System.out.println("实现的接口类名: " + interfaces[i].getName());

  166.     }

  167.  
  168. }

  169.  
  170. /**

  171. * Demo7: 通过Java反射机制调用类方法

  172. */

  173. public static void Test7() throws ClassNotFoundException, SecurityException, NoSuchMethodException, IllegalArgumentException, IllegalAccessException, InvocationTargetException, InstantiationException {

  174.     Class<?> class1 = null;

  175.     class1 = Class.forName("com.android.reflect.SuperPerson");

  176.  
  177.     System.out.println("Test7: \n调用无参方法fly():");

  178.     Method method = class1.getMethod("fly");

  179.     method.invoke(class1.newInstance());

  180.  
  181.     System.out.println("调用有参方法smoke(int m):");

  182.     method = class1.getMethod("smoke", int.class);

  183.     method.invoke(class1.newInstance(), 100);

  184. }

  185.  
  186. /**

  187. * Demo8: 通过Java反射机制得到类加载器信息

  188. * <p/>

  189. * 在java中有三种类类加载器。

  190. * <p/>

  191. * 1)Bootstrap ClassLoader 此加载器采用c++编写,一般开发中很少见。

  192. * <p/>

  193. * 2)Extension ClassLoader 用来进行扩展类的加载,一般对应的是jre\lib\ext目录中的类

  194. * <p/>

  195. * 3)AppClassLoader 加载classpath指定的类,是最常用的加载器。同时也是java中默认的加载器。

  196. *

  197. * @throws ClassNotFoundException

  198. */

  199. public static void Test8() throws ClassNotFoundException {

  200.     Class<?> class1 = null;

  201.     class1 = Class.forName("com.android.reflect.SuperPerson");

  202.     String name = class1.getClassLoader().getClass().getName();

  203.  
  204.     System.out.println("Test8: 类加载器类名: " + name);

  205. }

 

 

 

 

 

运行结果:

 
  1. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ Test1: 包名: com.tuba.yuanyc.audiomanagerdemo,完整类名: com.tuba.yuanyc.audiomanagerdemo.Person

  2. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ ===============================================

  3. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ Test2:(写法1) 包名: com.android.reflect,完整类名: com.tuba.yuanyc.audiomanagerdemo.Person

  4. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ Test2:(写法2) 包名: com.android.reflect,完整类名: com.tuba.yuanyc.audiomanagerdemo.Person

  5. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ ===============================================

  6. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ Test3: zhuk : 26

  7. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ ===============================================

  8. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ Test4: yyc : 28  ,   yyc : 29

  9. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ ===============================================

  10. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ Test5: 修改属性之后得到属性变量的值:cyy

  11. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ ===============================================

  12. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ Test6:  SuperMan类的父类名: java.lang.Object

  13. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ ===============================================

  14. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ 类中的成员: private java.lang.String com.tuba.yuanyc.audiomanagerdemo.Person.name

  15. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ 类中的成员: private int com.android.reflect.Person.age

  16. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ ===============================================

  17. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ Test6,取得SuperMan类的方法:

  18. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ 函数名:getAge

  19. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ 函数返回类型:int

  20. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ 函数访问修饰符:public

  21. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ 函数代码写法: public int com.tuba.yuanyc.audiomanagerdemo.Person.getAge()

  22. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ Test6,取得SuperMan类的方法:

  23. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ 函数名:getName

  24. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ 函数返回类型:class java.lang.String

  25. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ 函数访问修饰符:public

  26. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ 函数代码写法: public java.lang.String com.tuba.yuanyc.audiomanagerdemo.Person.getName()

  27. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ Test6,取得SuperMan类的方法:

  28. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ 函数名:setAge

  29. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ 函数返回类型:void

  30. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ 函数访问修饰符:public

  31. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ 函数代码写法: public void com.tuba.yuanyc.audiomanagerdemo.Person.setAge(int)

  32. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ Test6,取得SuperMan类的方法:

  33. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ 函数名:setName

  34. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ 函数返回类型:void

  35. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ 函数访问修饰符:public

  36. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ 函数代码写法: public void com.tuba.yuanyc.audiomanagerdemo.Person.setName(java.lang.String)

  37. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ ===============================================

  38. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ ===============================================

  39. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ Test7:

  40. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ 调用无参方法fly():

  41. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ 走你~~

  42. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ 调用有参方法smoke(int m):

  43. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ ===============================================

  44. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ Test8: 类加载器类名: dalvik.system.PathClassLoader

  45. 01-28 17:19:29.463  14972-14972/? I/System.out﹕ ===============================================  

 

 

 

 

利用反射使用系统隐藏类

      因为SystemProperties.java类已被系统隐藏,因此我们通过Java反射机制获取该类内容,通过get和set方法来读取、设置build.prop里面的内容。

 
  1. package com.android.kaiven.tools;  

  2.   

  3. import android.content.Context;  

  4. import android.util.Log;  

  5.   

  6. import java.io.File;  

  7. import java.io.IOException;  

  8. import java.lang.reflect.Method;  

  9.   

  10. import dalvik.system.DexFile;  

  11.   

  12. /** 

  13.  * Created by zhangqing on 2017/3/1. 

  14.  */  

  15. public class SystemPropertiesProxy {  

  16.     public static final String TAG = "SystemPropertiesProxy";  

  17.   

  18.     /** 

  19.      * 根据给定的Key返回String类型的值 

  20.      * 

  21.      * @param context 上下文 

  22.      * @param key     获取指定信息所需的key 

  23.      * @return 返回一个String类型的值,如果不存在该key则返回空字符串 

  24.      */  

  25.     public static String getString(Context context, String key) {  

  26.         String result = "";  

  27.         try {  

  28.             ClassLoader classLoader = context.getClassLoader();  

  29.             @SuppressWarnings("rawtypes")  

  30.             Class SystemProperties = classLoader.loadClass("android.os.SystemProperties");  

  31.             //参数类型  

  32.             @SuppressWarnings("rawtypes")  

  33.             Class[] paramTypes = new Class[1];  

  34.             paramTypes[0] = String.class;  

  35.             Method getString = SystemProperties.getMethod("get", paramTypes);  

  36.             //参数  

  37.             Object[] params = new Object[1];  

  38.             params[0] = new String(key);  

  39.   

  40.             result = (String) getString.invoke(SystemProperties, params);  

  41.         } catch (IllegalArgumentException e) {  

  42.             //e.printStackTrace();  

  43.             //如果key超过32个字符则抛出该异常  

  44.             Log.w(TAG, "key超过32个字符");  

  45.         } catch (Exception e) {  

  46.             result = "";  

  47.         }  

  48.         return result;  

  49.     }  

  50.   

  51.     /** 

  52.      * 根据给定的Key返回String类型的值 

  53.      * 

  54.      * @param context 上下文 

  55.      * @param key     获取指定信息所需的key 

  56.      * @param def     key不存在时的默认值 

  57.      * @return 返回一个String类型的值,如果key不存在, 并且如果def不为null则返回def,否则返回空字符串 

  58.      */  

  59.     public static String getString(Context context, String key, String def) {  

  60.         String result = def;  

  61.         try {  

  62.             ClassLoader classLoader = context.getClassLoader();  

  63.             @SuppressWarnings("rawtypes")  

  64.             Class SystemProperties = classLoader.loadClass("android.os.SystemProperties");  

  65.             //参数类型  

  66.             @SuppressWarnings("rawtypes")  

  67.             Class[] paramTypes = new Class[2];  

  68.             paramTypes[0] = String.class;  

  69.             paramTypes[1] = String.class;  

  70.             Method getString = SystemProperties.getMethod("get", paramTypes);  

  71.             //参数  

  72.             Object[] params = new Object[2];  

  73.             params[0] = new String(key);  

  74.             params[1] = new String(def);  

  75.   

  76.             result = (String) getString.invoke(SystemProperties, params);  

  77.         } catch (IllegalArgumentException e) {  

  78.             //e.printStackTrace();  

  79.             //如果key超过32个字符则抛出该异常  

  80.             Log.w(TAG, "key超过32个字符");  

  81.         } catch (Exception e) {  

  82.             result = def;  

  83.         }  

  84.         return result;  

  85.     }  

  86.   

  87.     /** 

  88.      * 根据给定的key返回int类型的值 

  89.      * 

  90.      * @param context 上下文 

  91.      * @param key     要查询的key 

  92.      * @param def     默认返回值 

  93.      * @return 返回一个int类型的值,如果没有发现则返回默认值 def 

  94.      */  

  95.     public static Integer getInt(Context context, String key, int def) {  

  96.         Integer result = def;  

  97.         try {  

  98.             ClassLoader classLoader = context.getClassLoader();  

  99.             @SuppressWarnings("rawtypes")  

  100.             Class SystemProperties = classLoader.loadClass("android.os.SystemProperties");  

  101.             //参数类型  

  102.             @SuppressWarnings("rawtypes")  

  103.             Class[] paramTypes = new Class[2];  

  104.             paramTypes[0] = String.class;  

  105.             paramTypes[1] = int.class;  

  106.             Method getInt = SystemProperties.getMethod("getInt", paramTypes);  

  107.             //参数  

  108.             Object[] params = new Object[2];  

  109.             params[0] = new String(key);  

  110.             params[1] = new Integer(def);  

  111.             result = (Integer) getInt.invoke(SystemProperties, params);  

  112.         } catch (IllegalArgumentException e) {  

  113.             //e.printStackTrace();  

  114.             //如果key超过32个字符则抛出该异常  

  115.             Log.w(TAG, "key超过32个字符");  

  116.         } catch (Exception e) {  

  117.             result = def;  

  118.         }  

  119.         return result;  

  120.     }  

  121.   

  122.     /** 

  123.      * 根据给定的key返回long类型的值 

  124.      * 

  125.      * @param context 上下文 

  126.      * @param key     要查询的key 

  127.      * @param def     默认返回值 

  128.      * @return 返回一个long类型的值,如果没有发现则返回默认值def 

  129.      */  

  130.     public static Long getLong(Context context, String key, long def) {  

  131.         Long result = def;  

  132.         try {  

  133.             ClassLoader classLoader = context.getClassLoader();  

  134.             @SuppressWarnings("rawtypes")  

  135.             Class SystemProperties = classLoader.loadClass("android.os.SystemProperties");  

  136.             //参数类型  

  137.             @SuppressWarnings("rawtypes")  

  138.             Class[] paramTypes = new Class[2];  

  139.             paramTypes[0] = String.class;  

  140.             paramTypes[1] = long.class;  

  141.             Method getLong = SystemProperties.getMethod("getLong", paramTypes);  

  142.             //参数  

  143.             Object[] params = new Object[2];  

  144.             params[0] = new String(key);  

  145.             params[1] = new Long(def);  

  146.             result = (Long) getLong.invoke(SystemProperties, params);  

  147.         } catch (IllegalArgumentException e) {  

  148.             //e.printStackTrace();  

  149.             //如果key超过32个字符则抛出该异常  

  150.             Log.w(TAG, "key超过32个字符");  

  151.         } catch (Exception e) {  

  152.             result = def;  

  153.         }  

  154.         return result;  

  155.     }  

  156.   

  157.     /** 

  158.      * 根据给定的key返回boolean类型的值 

  159.      * 如果值为'n','no','0','false' or 'off'返回false 

  160.      * 如果值为'y','yes','1','true' or 'on'返回true 

  161.      * 如果key不存在, 或者是其它的值, 则返回默认值 

  162.      * 

  163.      * @param context 上下文 

  164.      * @param key     要查询的key 

  165.      * @param def     默认返回值 

  166.      * @return 返回一个boolean类型的值,如果没有发现则返回默认值def 

  167.      */  

  168.     public static Boolean getBoolean(Context context, String key, boolean def) {  

  169.         Boolean result = def;  

  170.         try {  

  171.             ClassLoader classLoader = context.getClassLoader();  

  172.             @SuppressWarnings("rawtypes")  

  173.             Class SystemProperties = classLoader.loadClass("android.os.SystemProperties");  

  174.             //参数类型  

  175.             @SuppressWarnings("rawtypes")  

  176.             Class[] paramTypes = new Class[2];  

  177.             paramTypes[0] = String.class;  

  178.             paramTypes[1] = boolean.class;  

  179.             Method getBoolean = SystemProperties.getMethod("getBoolean", paramTypes);  

  180.             //参数  

  181.             Object[] params = new Object[2];  

  182.             params[0] = new String(key);  

  183.             params[1] = new Boolean(def);  

  184.             result = (Boolean) getBoolean.invoke(SystemProperties, params);  

  185.         } catch (IllegalArgumentException e) {  

  186.             //e.printStackTrace();  

  187.             //如果key超过32个字符则抛出该异常  

  188.             Log.w(TAG, "key超过32个字符");  

  189.         } catch (Exception e) {  

  190.             result = def;  

  191.         }  

  192.         return result;  

  193.     }  

  194.   

  195.     /** 

  196.      * 根据给定的key和值设置属性, 该方法需要特定的权限才能操作. 

  197.      * 

  198.      * @param context 上下文 

  199.      * @param key     设置属性的key 

  200.      * @param val     设置属性的value 

  201.      */  

  202.     public static void set(Context context, String key, String val) {  

  203.         try {  

  204.             @SuppressWarnings("rawtypes")  

  205.             DexFile df = new DexFile(new File("/system/app/Settings.apk"));  

  206.             ClassLoader classLoader = context.getClassLoader();  

  207.             @SuppressWarnings("rawtypes")  

  208.             Class SystemProperties = Class.forName("android.os.SystemProperties");  

  209.             //参数类型  

  210.             @SuppressWarnings("rawtypes")  

  211.             Class[] paramTypes = new Class[2];  

  212.             paramTypes[0] = String.class;  

  213.             paramTypes[1] = String.class;  

  214.             Method set = SystemProperties.getMethod("set", paramTypes);  

  215.             //参数  

  216.             Object[] params = new Object[2];  

  217.             params[0] = new String(key);  

  218.             params[1] = new String(val);  

  219.             set.invoke(SystemProperties, params);  

  220.         } catch (IllegalArgumentException e) {  

  221.             //e.printStackTrace();  

  222.             //如果key超过32个字符或者value超过92个字符则抛出该异常  

  223.             Log.w(TAG, "key超过32个字符或者value超过92个字符");  

  224.         } catch (Exception e) {  

  225.             e.printStackTrace();  

  226.         }  

  227.     }  

  228.  

  • 3
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值