1、首先两者的区别:

  1、getApplicationContext()返回的是应用的上下文,隶属于整个应用,应用结束时才摧毁。

  2、Activity.this返回到是Activity的上下文,隶属于Activiy,当Activity实例摧毁时它就跟着摧毁了。

2、两者的使用:

  1、 getApplicationContext()是跟Windows无关的,所以不能做对话框的上下文,它可以做全局数据操作的上下文。

  2、Activity.this是跟Windows相关的,所以新建对话框的需要使用Activity.this。否则会报错。

3、Context的应用场景

android activity传到service android activity context_Windows

大家注意看到有一些NO上添加了一些数字,其实这些从能力上来说是YES,但是为什么说是NO呢?下面一个一个解释:

数字1:启动Activity在这些类中是可以的,但是需要创建一个新的task。一般情况不推荐。

数字2:在这些类中去layout inflate是合法的,但是会使用系统默认的主题样式,如果你自定义了某些样式可能不会被使用。

数字3:在receiver为null时允许,在4.2或以上的版本中,用于获取黏性广播的当前值。(可以无视)

建议:尽量不要使用getBaseContext()。这里有一篇关于Context的文章比较好大家可以看看

参考博客,里面还有大牛博客的案例,比如电商的刮刮卡!!等主流控件应用!!!

转载地址

1、首先两者的区别:

  1、getApplicationContext()返回的是应用的上下文,隶属于整个应用,应用结束时才摧毁。

  2、Activity.this返回到是Activity的上下文,隶属于Activiy,当Activity实例摧毁时它就跟着摧毁了。

2、两者的使用:

  1、 getApplicationContext()是跟Windows无关的,所以不能做对话框的上下文,它可以做全局数据操作的上下文。

  2、Activity.this是跟Windows相关的,所以新建对话框的需要使用Activity.this。否则会报错。

3、Context的应用场景

android activity传到service android activity context_Windows

大家注意看到有一些NO上添加了一些数字,其实这些从能力上来说是YES,但是为什么说是NO呢?下面一个一个解释:

数字1:启动Activity在这些类中是可以的,但是需要创建一个新的task。一般情况不推荐。

数字2:在这些类中去layout inflate是合法的,但是会使用系统默认的主题样式,如果你自定义了某些样式可能不会被使用。

数字3:在receiver为null时允许,在4.2或以上的版本中,用于获取黏性广播的当前值。(可以无视)

建议:尽量不要使用getBaseContext()。这里有一篇关于Context的文章比较好大家可以看看

参考博客,里面还有大牛博客的案例,比如电商的刮刮卡!!等主流控件应用!!!