Skip to main content

Working with Android Shared Preferences

          Shared preferences allows android application to save data in the form of "Key-Value" pair, shared preferences will be an , XML file which will be stored in applications internal storage space under "shared_prefs" folder under data/data/(package name of the application).

Shared Preferences won't clear data after "force close" of an application, it will get cleared only in case of user clears the application data (under settings -> apps -> clear Data) or uninstall an application.

Shared preferences can be edited using SharedPreferences.Editor class. APIs to access shared preference below,

  • getDefaultSharedPreferences()  :- Return default shared preference file which is used by PrefrenceManager in the given context.
  • getSharedPreferences(String my_prf_name, int mode) :- Returns shared preference file of the given name.
Below are  sample code snippets,

1. Saving data in to the shared preferences,
//Retrieve shared preference file obj by giving preference file name,
SharedPreferences sp = mContext.getSharedPreferences(my_prf_name, Context.MODE_PRIVATE);
// create shared pref editor object,
SharedPreferences.Editor editor = sp.edit();
editor.putBoolean("isLoggedInClient",1);  // put values to save
editor.commit();

2. Retrieving data from Shared preferences,

SharedPreferences sp = mContext.getSharedPreferences(my_prf_name, Context.MODE_PRIVATE);
sp.getBoolean("isLoggedInClient", false);  // "false" is the default value to return in case of key not found in shared pref

3. Retrieving all data from shared preferences,

SharedPreferences sp = mContext.getSharedPreferences(my_prf_name, Context.MODE_PRIVATE);
Map allEntries = sp.getAll();  // returns Map obj
for (Map.Entry entry : allEntries.entrySet()) {
 Log.d("shared Prefrence values", "KEY :- "+entry.getKey() + "Value :-" + entry.getValue().toString());
}

Happy Coding!!!

Comments

Popular posts from this blog

Launch an Android application on Bootup

If you want to start an android application on device restarts, you need to listen for BOOT_COMPLETED broadcast in the manifest file and launch the Launcher activity in onreceive of BOOT_COMPLETED broadcast receiver. Follow below steps to launch activity on device boot up :- 1. Register for Boot completed receiver in Android Manifest file. Add below Permission to receive BOOT_COMPLETED broadcast, <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" /> Register for Boot completed broadcast receiver , <receiver android:name="AppAutostartReceiver" android:enabled="true" > <intent-filter> <action android:name="android.intent.action.BOOT_COMPLETED" /> </intent-filter> </receiver> 2. Add custom Broadcast receiver in the application, public class AppAutostartReceiver extends BroadcastReceiver { @Override public void onReceive(Context cont...

Whitelist an android application on android 6.0/Marshmallow

Whitelist wont disable doze mode for your app, however can use network and hold wake lock. Whitelist an android application through code, boolean isIgnoringBatteryOptimizations = pm.isIgnoringBatteryOptimizations(getPackageName()); if(!isIgnoringBatteryOptimizations){   Intent intent = new Intent();   intent.setAction(Settings.ACTION_REQUEST_IGNORE_BATTERY_OPTIMIZATIONS);   intent.setData(Uri.parse("package:" + getPackageName()));   startActivityForResult(intent, MY_IGNORE_OPTIMIZATION_REQUEST);   }                             Check for the result, @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) {     if (requestCode == MY_IGNORE_OPTIMIZATION_REQUEST) {          PowerManager pm = (PowerManager)getSystemService(Context.POWER_SERVICE);          boolean isIgnoringBatteryOptimiza...