This might be a simple question but I just wanted to make sure I am right. In my android application I have a constructor that uses:
activity.getApplicationContext()
The activity is passed into the constructor as a parameter. The problem is that I am calling this class from a Service. If I make a second constructor which accepts the Service as a parameter and uses service.getApplicationContext ? Will I get the same application context?
5,867 72 72 gold badges 60 60 silver badges 132 132 bronze badges asked Aug 22, 2011 at 7:12 1,513 6 6 gold badges 21 21 silver badges 38 38 bronze badgesI have a very similar question - I have an app that has more than one process. There is a library that needs a class loader but is not itself an application but used in applications. It may be in more than one process in the application. Is there a way to get the current processes context from a library using some global object accessable in any process from a library so I can call context.getClassLoader()?
Commented Aug 28, 2015 at 23:08The easiest way to get the application context is:
Create a class App that extends android.app.Application
public class App extends Application < public static Context context; @Override public void onCreate() < super.onCreate(); context = getApplicationContext(); >>
Modify your AndroidManifest.xml 's tag to have the attribute android:name="your.package.name.App" .
Any time you need the application context, just get it from App.context .
Application is always initialized first whether your process runs, whether it's an activity, a service, or something else. You will always have access to the application context.
answered Aug 22, 2011 at 8:08 Randy Sugianto 'Yuku' Randy Sugianto 'Yuku' 72.9k 58 58 gold badges 185 185 silver badges 233 233 bronze badgesI saw the exact same approach somewhere and I'm using it to make application context accessible throughout my whole application. But I was not sure, is it the best practice to achieve this? Why accessing the context of application is not supplied as a built-in feature in android SDK?
Commented Jul 18, 2013 at 11:41getApplicationContext as you said is a method of Context class or its sub-classes. But assume you are creating a class that overrides AsyncTask to do some stuff in your application. And you wanna manipulate the UI in onPostExecute for example. Anyway, I think life would be more easier if getApplicationContext were static.
Commented Apr 9, 2014 at 8:55Android Studio gives this warning for this code - Do not place Android context classes in static fields; this is a memory leak (and also breaks Instant Run) . Is this really the best way to implement global context variable?
Commented Dec 20, 2016 at 17:43 this is a memory leak Commented Jan 24, 2017 at 6:40 Application is not initialized first, Content Providers are initialized before it. Commented Oct 3, 2017 at 3:25Will I get the same application context?
Yes. You can check the android documentation, they have provided
getApplicationContext()
Return the context of the single, global Application object of the current process.
So it should not be changed for the whole application process.
Please also take a note of this:
getApplicationContext() generally should only be used if you need a Context whose lifecycle is separate from the current context, that is tied to the lifetime of the process rather than the current component.
Correct me if I'm wrong.
103 1 1 silver badge 9 9 bronze badges answered Aug 22, 2011 at 7:21 3,494 4 4 gold badges 35 35 silver badges 32 32 bronze badgesThere is only one application context, so you should get the same one. You can have just one constructor that takes a Context , you don't really need two. Or if you wanted to make sure that you are getting the application context, and not, say, an activity one, you can have your constructor take Application as a parameter which is a Context .
answered Aug 22, 2011 at 7:21 Nikolay Elenkov Nikolay Elenkov 52.9k 11 11 gold badges 85 85 silver badges 84 84 bronze badgesYou can go for getApplicationContext() if you wanna get context of whole application. If you want to get context of current class you can use getBaseContext() instead.
623 1 1 gold badge 7 7 silver badges 14 14 bronze badges answered Aug 22, 2011 at 7:24 Android Killer Android Killer 18.4k 15 15 gold badges 69 69 silver badges 93 93 bronze badgesI have adapted yuku's answer with a non static direct context reference.
Create a class domain.company.pseudo.ApplicationName which extends android.app.Application .
package hypersoft.systems.android; import android.app.Application; public class Starbox extends Application < public static Starbox instance; @Override public void onCreate() < super.onCreate(); instance = this; >>
In this sample, my full application package name is hypersoft.systems.android.starbox .
Now, modify your AndroidManifest.xml tag to have the attribute android:name="hypersoft.systems.android.Starbox" , and be sure the Starbox.java class file is located in the project component directory: android rather than starbox .
With all this done, you can now import hypersoft.systems.android.Starbox , and in your code you can get the ApplicationContext by calling Starbox.instance.getApplicationContext()
Successfully compiling with build tools 26 and api 26 (Android 8.0) with min sdk version 14 (4.0).