Android中Context参数解释
2018-03-22 12:29
387 查看
context的作用,就是android应用连接service的桥梁。
比如Activity中有经常会有可能调用到系统的service,使用getSystemService()方法,这个方法调到最后,实际上是调用的ContextImpl的getSystemService()方法。而ContextImpl是针对参数Context的实现形式,所以需要传入参数context。
在Android系统中,有很多的service,也就是服务。程序如果用到系统功能,一般都是调用服务间接完成的。
Context字面意思指的是上下文,位于framework package的android.content.Context中,其实该类为LONG型,类似Win32中的Handle句柄,很多方法需要通过
Context才能识别调用者的实例,比如说Toast的第一个参数就是Context,一般在Activity中我们直接用this代替,所以当在Fragment中若要使用Context参数,首先要定义
[java] view plain copy print?context=this.getActivity();
[java] view plain copy print?manager = (UsbManager) activity.getSystemService(Context.USB_SERVICE);
但是如果这一段代码直接放在activity中的时候可以直接用this关键字代替。
[java] view plain copy print?manager = (UsbManager) this.getSystemService(Context.USB_SERVICE);
代表调用者的实例为Activity,而到了一个button的onClick(View
view)等方法时,我们用this时就会报错,所以我们可能使用ActivityName.this来解决,主要原因是因为实现Context的类主要有Android特有的几个模型,Activity、Service以及BroadcastReceiver。
常规需要Context实例的方法主要有各种Service实现的类,比如说SensorManager在实例化时需要
getSystemService(String)方法就必须由Context的实例执行,还有一些私有的文件系统I/O比如说 openFileInput以及常用的Toast的makeText方法。
转自风轻云喏的博客:http://blog.csdn.net/a550508153/article/details/50237091
比如Activity中有经常会有可能调用到系统的service,使用getSystemService()方法,这个方法调到最后,实际上是调用的ContextImpl的getSystemService()方法。而ContextImpl是针对参数Context的实现形式,所以需要传入参数context。
在Android系统中,有很多的service,也就是服务。程序如果用到系统功能,一般都是调用服务间接完成的。
Context字面意思指的是上下文,位于framework package的android.content.Context中,其实该类为LONG型,类似Win32中的Handle句柄,很多方法需要通过
Context才能识别调用者的实例,比如说Toast的第一个参数就是Context,一般在Activity中我们直接用this代替,所以当在Fragment中若要使用Context参数,首先要定义
[java] view plain copy print?context=this.getActivity();
context=this.getActivity();
[java] view plain copy print?manager = (UsbManager) activity.getSystemService(Context.USB_SERVICE);
manager = (UsbManager) activity.getSystemService(Context.USB_SERVICE);
但是如果这一段代码直接放在activity中的时候可以直接用this关键字代替。
[java] view plain copy print?manager = (UsbManager) this.getSystemService(Context.USB_SERVICE);
manager = (UsbManager) this.getSystemService(Context.USB_SERVICE);
代表调用者的实例为Activity,而到了一个button的onClick(View
view)等方法时,我们用this时就会报错,所以我们可能使用ActivityName.this来解决,主要原因是因为实现Context的类主要有Android特有的几个模型,Activity、Service以及BroadcastReceiver。
常规需要Context实例的方法主要有各种Service实现的类,比如说SensorManager在实例化时需要
getSystemService(String)方法就必须由Context的实例执行,还有一些私有的文件系统I/O比如说 openFileInput以及常用的Toast的makeText方法。
转自风轻云喏的博客:http://blog.csdn.net/a550508153/article/details/50237091
相关文章推荐
- 关于Android Canvas.drawText方法中的坐标参数的正确解释
- 关于android布局属性tools:context最通俗的解释
- 关于Android Canvas.drawText方法中的坐标参数的正确解释
- <Context path="" docBase="reports" debug="0" reloadable="true"/> 中 debug 参数解释
- Android中Context具体解释 ---- 你所不知道的Context
- Android中Context具体解释 ---- 你所不知道的Context
- 关于Android Canvas.drawText方法中的坐标参数的正确解释
- Android中Context具体解释 ---- 你所不知道的Context
- android关于 LayoutInflater.from(context)中参数的问题
- Android makefile mk 重要参数解释及 通用模板编写
- Android Canvas.drawText方法中的坐标参数的正确解释
- Android中Context具体解释 ---- 你所不知道的Context
- 关于Android Canvas.drawText方法中的坐标参数的正确解释
- 关于Android Canvas.drawText方法中的坐标参数的正确解释
- Android中Context具体解释 ---- 你所不知道的Context
- Android中Context具体解释 ---- 你所不知道的Context
- Android 通知栏 PendingIntent.getActivity(context, requestCode, intent, flags);参数详解
- android make file 参数解释及模板(即 android.mk内容解释)
- android StaticLayout参数解释
- 关于android中Context参数的理解