I already made some Apps in Android and noticed that I am often using static methods.
For example I have an Class which extends PreferenceFragment
. In t
In Android (in memory managed programming languages like Java, more precisely), static
methods can lead to "memory leaks" if not used correctly. I've quoted "memory leaks" as they are not the pure definition of memory leaks, like in C++ where you forget to remove some items from memory and lose the reference to them (and thus cannot clear them later on - at least not easily), but more like keeping on to references when you no longer need them and preventing the GC from doing its job in clearing that memory for you. There are a lot of articles on the web that cover this (search for "Android static memory leak") and a lot of other questions on SO that have been asked about this (see [static][Android][memory-leaks] tags), so I won't go into this.
For your particular case, in order to avoid possible memory leaks, you can get the Activity
from the Fragment
object that your anonymous OnClickListener
object is tied to by using MyFragmentClass.this.getActivity()
, cast it to, say, SettingsActivity
(as is the case here) and call .finishActivityWithResultOkey()
on it. It's best that you guard your cast too.
Here's an example of how the code could look like:
btn.setOnClickListener(new View.OnClickListener() {
public void onClick(View v) {
final Activity activity = MyFragmentClass.this.getActivity();
if(activity instanceof SettingsActivity)
((SettingsActivity)activity).finishActivityWithResultOkey();
else
throw new IllegalStateException("This OnClickListener requires a SettingsActivity to start the fragment containig it"); //helps with debugging
}
});
As a note: MyFragmentClass
refers to the class of the fragment that you're putting this code in :)