zoukankan      html  css  js  c++  java
  • Android在任意位置获取应用程序Context

    Android程序中访问资源时需要提供Context,一般来说只有在各种component中(Activity, Provider等等)才能方便的使用api来获取Context, 而在某些工具类中要获取就很麻烦了。为此,我们可以自定义一个Application类来实现这种功能。

    import android.app.Application;
    
    public class MyApplication extends Application {
    private static MyApplication instance;
    
    public static MyApplication getInstance() {
    return instance;
    }
    
    @Override
    public void onCreate() {
    // TODO Auto-generated method stub
    super.onCreate();
    instance = this;
    }
    }

    然后在manifest中<application>中加入name="mypackage.MyApplication"就可以在任意类中使用MyApplication.getInstance()来获取应用程序Context了。

    获取别的包的context 

    Android中有Context的概念,想必大家都知道。Context可以做很多事情,打开activity、发送广播、打开本包下文件夹和数据库、获取classLoader、获取资源等等。如果我们得到了一个包的Context对象,那我们基本上可以做这个包自己能做的大部分事情。 
    那我们能得到吗?很高兴的告诉你,能!
    Context有个createPackageContext方法,可以创建另外一个包的上下文,这个实例不同于它本身的Context实例,但是功能是一样的。


     这个方法有两个参数:
    1。packageName  包名,要得到Context的包名
    2。flags  标志位,有CONTEXT_INCLUDE_CODE和CONTEXT_IGNORE_SECURITY两个选项。

    CONTEXT_INCLUDE_CODE的意思是包括代码,也就是说可以执行这个包里面的代码。

    CONTEXT_IGNORE_SECURITY的意思是忽略安全警告,如果不加这个标志的话,有些功能是用不了的,会出现安全警告。


    下面给个小例子,执行另外一个包里面的某个类的方法。
    另外一个包的包名是chroya.demo,类名Main,方法名print,代码如下:

    package chroya.demo;   
       
    import android.app.Activity;   
    import android.os.Bundle;   
    import android.util.Log;   
       
    class Main extends Activity {   
           
        @Override   
        public void onCreate(Bundle savedInstanceState) {   
            super.onCreate(savedInstanceState);   
        }   
           
        public void print(String msg) {   
            Log.d("Main", "msg:"+ msg);   
        }   
    }   
    
    package chroya.demo;
    
    import android.app.Activity;
    import android.os.Bundle;
    import android.util.Log;
    
    class Main extends Activity {
     
     @Override
     public void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);
     }
     
     public void print(String msg) {
      Log.d("Main", "msg:"+ msg);
     }
    }

    本包的调用Main的print方法的代码块如下:

    Context c = createPackageContext("chroya.demo", Context.CONTEXT_INCLUDE_CODE | Context.CONTEXT_IGNORE_SECURITY);   
    //载入这个类   
    Class clazz = c.getClassLoader().loadClass("chroya.demo.Main");   
    //新建一个实例   
    Object owner = clazz.newInstance();   
    //获取print方法,传入参数并执行   
    Object obj = clazz.getMethod("print", String.class).invoke(owner, "Hello");   
    
    Context c = createPackageContext("chroya.demo", Context.CONTEXT_INCLUDE_CODE | Context.CONTEXT_IGNORE_SECURITY);
    //载入这个类
    Class clazz = c.getClassLoader().loadClass("chroya.demo.Main");
    //新建一个实例
    Object owner = clazz.newInstance();
    //获取print方法,传入参数并执行
    Object obj = clazz.getMethod("print", String.class).invoke(owner, "Hello");

    ok,这样,我们就调用了chroya.demo包的Main类的print方法,执行结果,打印出了Hello。

    怎么样,这只是一个调用其他包的代码的例子,我们获取到Context,还可以做很多事情,当然,题目所说的坏事,还是不要做为好。

  • 相关阅读:
    sql 删除重复行
    sql 内连接和外链接
    浏览器内核
    asp.net session
    使用powerdesigner创建数据库表
    数据库中char, varchar, nvarchar的差异
    概要设计和详细设计说明书的区别
    2.类和对象
    1.Basic Layouts
    1.初学c++,比较困惑的问题。
  • 原文地址:https://www.cnblogs.com/xuewater/p/2591487.html
Copyright © 2011-2022 走看看