26

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?

1
  • I 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:08

6 Answers 6

59

The 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 <application> 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.

Sign up to request clarification or add additional context in comments.

9 Comments

I 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?
getApplicationContext 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.
Android 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?
this is a memory leak
Application is not initialized first, Content Providers are initialized before it.
|
14

Will 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.

Thanks

Comments

3

There 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.

Comments

2

I 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 <application> 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).

1 Comment

Id be interested as to which approach is the better practice here. Because I cant see an upside to reveal the whole application object to the whole project when all one needs and uses is the context. Considering that use-case, is it necessary or better to still provide the whole application object instead just the component or function that is needed/used?
1

You 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.

Comments

-2

Application Context add Activity Context both are different.Downcasting is risky .Use this code to use context object .

public class App extends Application { public static Context context; @Override public void onCreate() { super.onCreate(); context = getApplicationContext(); } } 

In Your Activities and in fragments Class :

Conetext context=App.context;

Comments

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.