context

context(引用自  :http://blog.csdn.net/qinjuning)

       1、它描述的是一个应用程序环境的信息,即上下文。

        2、该类是一个抽象(abstract class)类,Android提供了该抽象类的具体实现类(后面我们会讲到是ContextIml类)。

        3、通过它我们可以获取应用程序的资源和类,也包括一些应用级别操作,例如:启动一个Activity,发送广播,接受Intent

          信息 等。。

 一、Context相关类的继承关系

 

                         

 

  相关类介绍:

 

   Context类    路径: /frameworks/base/core/java/android/content/Context.java

            说明:  抽象类,提供了一组通用的API。

      源代码(部分)如下:   

[java]  view plain  copy
 print ?
  1. public abstract class Context {  
  2.      ...  
  3.      public abstract Object getSystemService(String name);  //获得系统级服务  
  4.      public abstract void startActivity(Intent intent);     //通过一个Intent启动Activity  
  5.      public abstract ComponentName startService(Intent service);  //启动Service  
  6.      //根据文件名得到SharedPreferences对象  
  7.      public abstract SharedPreferences getSharedPreferences(String name,int mode);  
  8.      ...  
  9. }  

 

  ContextIml.java类  路径 :/frameworks/base/core/java/android/app/ContextImpl.java

          说明:该Context类的实现类为ContextIml,该类实现了Context类的功能。请注意,该函数的大部分功能都是直接调用

      其属性mPackageInfo去完成,这点我们后面会讲到。    

         源代码(部分)如下:

[java]  view plain  copy
 print ?
  1. /** 
  2.  * Common implementation of Context API, which provides the base 
  3.  * context object for Activity and other application components. 
  4.  */  
  5. class ContextImpl extends Context{  
  6.     //所有Application程序公用一个mPackageInfo对象  
  7.     /*package*/ ActivityThread.PackageInfo mPackageInfo;  
  8.       
  9.     @Override  
  10.     public Object getSystemService(String name){  
  11.         ...  
  12.         else if (ACTIVITY_SERVICE.equals(name)) {  
  13.             return getActivityManager();  
  14.         }   
  15.         else if (INPUT_METHOD_SERVICE.equals(name)) {  
  16.             return InputMethodManager.getInstance(this);  
  17.         }  
  18.     }   
  19.     @Override  
  20.     public void startActivity(Intent intent) {  
  21.         ...  
  22.         //开始启动一个Activity  
  23.         mMainThread.getInstrumentation().execStartActivity(  
  24.             getOuterContext(), mMainThread.getApplicationThread(), nullnull, intent, -1);  
  25.     }  
  26. }  

 


 

  ContextWrapper类 路径 :\frameworks\base\core\java\android\content\ContextWrapper.java

        说明: 正如其名称一样,该类只是对Context类的一种包装,该类的构造函数包含了一个真正的Context引用,即ContextIml

       对象。    源代码(部分)如下:

[java]  view plain  copy
 print ?
  1. public class ContextWrapper extends Context {  
  2.     Context mBase;  //该属性指向一个ContextIml实例,一般在创建Application、Service、Activity时赋值  
  3.       
  4.     //创建Application、Service、Activity,会调用该方法给mBase属性赋值  
  5.     protected void attachBaseContext(Context base) {  
  6.         if (mBase != null) {  
  7.             throw new IllegalStateException("Base context already set");  
  8.         }  
  9.         mBase = base;  
  10.     }  
  11.     @Override  
  12.     public void startActivity(Intent intent) {  
  13.         mBase.startActivity(intent);  //调用mBase实例方法  
  14.     }  
  15. }  

 


 

   ContextThemeWrapper类 路径:/frameworks/base/core/java/android/view/ContextThemeWrapper.java

      说明:该类内部包含了主题(Theme)相关的接口,即android:theme属性指定的。只有Activity需要主题,Service不需要主题,

   所以Service直接继承于ContextWrapper类。

      源代码(部分)如下:

[java]  view plain  copy
 print ?
  1. public class ContextThemeWrapper extends ContextWrapper {  
  2.      //该属性指向一个ContextIml实例,一般在创建Application、Service、Activity时赋值  
  3.        
  4.      private Context mBase;  
  5.     //mBase赋值方式同样有一下两种  
  6.      public ContextThemeWrapper(Context base, int themeres) {  
  7.             super(base);  
  8.             mBase = base;  
  9.             mThemeResource = themeres;  
  10.      }  
  11.   
  12.      @Override  
  13.      protected void attachBaseContext(Context newBase) {  
  14.             super.attachBaseContext(newBase);  
  15.             mBase = newBase;  
  16.      }  
  17. }  

 

 

     Activity类 、Service类 、Application类本质上都是Context子类, 更多信息大家可以自行参考源代码进行理解。

 



3;application全局的上下文,可以用于数据的共享。是程序的初始入口,会最开始调用oncreate()方法

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值