欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

SharePreference类似于JavaEE中的session

程序员文章站 2022-03-07 13:55:24
...

SharedPreference主要是保存一些常用的配置比如窗口状态,一般在Activity中 重载窗口状态onSaveInstanceState保存一般使用SharedPreferences完成。 类似过去Windows系统上的ini配置文件,但是它分为多种权限,可以全局共享访问。
例子:
工程1:

Java代码 SharePreference类似于JavaEE中的session
            
    
    博客分类: Android   SharePreference类似于JavaEE中的session
            
    
    博客分类: Android  
  1. SharedPreferences shp=getSharedPreferences(SharePreference_name, Context.MODE_WORLD_READABLE);   
  2.         SharedPreferences.Editor editor = shp.edit();   
  3.         editor.putInt("storedInt"100); // value to store   
  4.         editor.commit();  
SharedPreferences shp=getSharedPreferences(SharePreference_name, Context.MODE_WORLD_READABLE);
        SharedPreferences.Editor editor = shp.edit();
        editor.putInt("storedInt", 100); // value to store
        editor.commit();



工程2:

Java代码 SharePreference类似于JavaEE中的session
            
    
    博客分类: Android   SharePreference类似于JavaEE中的session
            
    
    博客分类: Android  
  1. Context mOtherContex;   
  2.         int storedPreference;   
  3.         try {   
  4.             mOtherContex = this.createPackageContext("com.android.testsharepreference", Context.CONTEXT_IGNORE_SECURITY);   
  5.                SharedPreferences preferences = mOtherContex.getSharedPreferences(SharePreference_name,MODE_WORLD_READABLE);   
  6.                storedPreference = preferences.getInt("storedInt"0);   
  7.                    
  8.         } catch (NameNotFoundException e) {   
  9.             // TODO Auto-generated catch block   
  10.             e.printStackTrace();   
  11.             storedPreference=200;   
  12.         }  
Context mOtherContex;
        int storedPreference;
		try {
			mOtherContex = this.createPackageContext("com.android.testsharepreference", Context.CONTEXT_IGNORE_SECURITY);
			   SharedPreferences preferences = mOtherContex.getSharedPreferences(SharePreference_name,MODE_WORLD_READABLE);
			   storedPreference = preferences.getInt("storedInt", 0);
		    	
		} catch (NameNotFoundException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
			storedPreference=200;
		}



解说:工程1创建getSharedPreferences(SharePreference_name, Context.MODE_WORLD_READABLE);第二个参数就可以决定你的SharePreference要不要共享,有三种模式:MODE_PRIVATE ,MODE_WORLD_READABLE, MODE_WORLD_WRITEABLE;工程2 getSharedPreferences是通过工程1的Context来获得工程1的SharedPreference的实例。

 

 

========================================================

 

 

 

 

Java代码 SharePreference类似于JavaEE中的session
            
    
    博客分类: Android   SharePreference类似于JavaEE中的session
            
    
    博客分类: Android  
  1. <SPAN style="FONT-SIZE: medium">SharedPreferences    getPreferences(int mode)  通过Activity可以返回一个SharedPrefenences的实</SPAN>例  
SharedPreferences  	 getPreferences(int mode)  通过Activity可以返回一个SharedPrefenences的实

 

Java代码 SharePreference类似于JavaEE中的session
            
    
    博客分类: Android   SharePreference类似于JavaEE中的session
            
    
    博客分类: Android  
  1. <SPAN style="FONT-SIZE: medium">在Context下有这个方法  根据文件名称和mode来实例化SharedPreferences对象   
  2. abstract SharedPreferences   
  3.     getSharedPreferences(String name, int mode)   
  4. Retrieve and hold the contents of the preferences file 'name', returning a SharedPreferences through which you can retrieve and modify its values.   
  5. </SPAN>  
在Context下有这个方法  根据文件名称和mode来实例化SharedPreferences对象
abstract SharedPreferences
	getSharedPreferences(String name, int mode)
Retrieve and hold the contents of the preferences file 'name', returning a SharedPreferences through which you can retrieve and modify its values.
  
  因为Activity继承于Context,则在Activity都可以通过以上两种方法来实例化SharedPreferences对象


得到了SharedPreferences对象,就可以使用下面的方法。

Java代码 SharePreference类似于JavaEE中的session
            
    
    博客分类: Android   SharePreference类似于JavaEE中的session
            
    
    博客分类: Android  
  1. <SPAN style="FONT-SIZE: small"><STRONG>public interface  
  2. SharedPreferences   
  3.   
  4. <!-- end header -->   
  5. android.content.SharedPreferences   
  6. Class Overview   
  7.   
  8. Interface for accessing and modifying preference data returned by getSharedPreferences(String, int) . For any particular set of preferences, there is a single instance of this class that all clients share. Modifications to the preferences must go through an SharedPreferences.Editor object to ensure the preference values remain in a consistent state and control when they are committed to storage.   
  9.   
  10. Note: currently this class does not support use across multiple processes. This will be added later.   
  11. See Also</STRONG></SPAN>   
  12.   
  13.  <SPAN style="FONT-SIZE: small">   * getSharedPreferences(String, int)   
  14.   
  15. SharedPreferences是一个接口,如果想添加和修改Preference data,就要通过getSharedPreferences(String,int)。在一个类里面实例化,就可以在其它地方共享这些数据。   
  16. 目前这个类不支持多进程使用。   
  17.   
  18.   
  19. <!-- jd-descr -->   
  20. Summary   
  21.   
  22. <!-- ======== NESTED CLASS SUMMARY ======== -->   
  23. </SPAN>   
  24. <SPAN style="FONT-SIZE: medium"><STRONG>Nested Classes   
  25.   
  26. 这两个接口是SharedPreferences的内部类   
  27. interface   SharedPreferences.Editor    SharedPreferences编辑器   
  28. interface   SharedPreferences.OnSharedPreferenceChangeListener   当数据改变的时候调用   
  29. <!-- ========== METHOD SUMMARY =========== -->   
  30. Public Methods   
  31. abstract boolean    contains (String key)   数据库里是否包含key的键值   
  32. abstract SharedPreferences.Editor   edit ()      通过这个方法返回一个SharedPrefenences.Editor实例化对象   
  33. abstract Map <String , ?>     getAll ()  返回所有的键值对,注意“?”,它代表你存储的数字类型,是泛型的用法   
  34. abstract boolean    getBoolean (String key, boolean defValue) 通过key从Preferences获取boolean类型的数据   
  35. abstract float  getFloat (String key, float defValue) 通过key从Preferences获取float类型的数据   
  36. abstract int    getInt (String key, int defValue) 通过key从Preferences获取int类型的数据   
  37. abstract long   getLong (String key, long defValue) 通过key从Preferences获取long类型的数据   
  38. abstract String     getString (String key, String defValue) 通过key从Preferences获取String类型的数据   
  39. abstract void   registerOnSharedPreferenceChangeListener (SharedPreferences.OnSharedPreferenceChangeListener listener)   
  40. 注册一个监听器。当preferences数据改变的时候调用这个监听器下的方法   
  41. abstract void   unregisterOnSharedPreferenceChangeListener (SharedPreferences.OnSharedPreferenceChangeListener listener)   
  42. 注册一个监听器。取消先前注册的回调方法。</STRONG></SPAN>   
  43.   
  44.   
  45.   
  46. <SPAN style="FONT-SIZE: medium">通过上面的editor() 方法就可以实例化SharedPreferences.Editor对象,接着就可以使用下面的一些方法进行存储。   
  47. </SPAN>   
  48.   
  49. <SPAN style="FONT-SIZE: medium"><STRONG>Public Methods   
  50. abstract SharedPreferences.Editor      
  51.   
  52.                                          
  53. abstract boolean    clear ()    删除所有值   
  54.   
  55. commit ()   提交你设置的值   
  56. abstract SharedPreferences.Editor   putBoolean (String key, boolean value)   设置boolean值存储   
  57. abstract SharedPreferences.Editor   putFloat (String key, float value)  设置浮点型数据存储   
  58. abstract SharedPreferences.Editor   putInt (String key, int value)  设置整形数据存储   
  59. abstract SharedPreferences.Editor   putLong (String key, long value) 设置长整型   
  60. abstract SharedPreferences.Editor   putString (String key, String value)  设置字符串数据存储   
  61. abstract SharedPreferences.Editor      
  62.   
  63. remove (String key)  删除一个</STRONG></SPAN>  
public interface
SharedPreferences

<!-- end header -->
android.content.SharedPreferences
Class Overview

Interface for accessing and modifying preference data returned by getSharedPreferences(String, int) . For any particular set of preferences, there is a single instance of this class that all clients share. Modifications to the preferences must go through an SharedPreferences.Editor object to ensure the preference values remain in a consistent state and control when they are committed to storage.

Note: currently this class does not support use across multiple processes. This will be added later.
See Also

    * getSharedPreferences(String, int)

SharedPreferences是一个接口,如果想添加和修改Preference data,就要通过getSharedPreferences(String,int)。在一个类里面实例化,就可以在其它地方共享这些数据。
目前这个类不支持多进程使用。


<!-- jd-descr -->
Summary

<!-- ======== NESTED CLASS SUMMARY ======== -->

Nested Classes

这两个接口是SharedPreferences的内部类
interface 	SharedPreferences.Editor 	SharedPreferences编辑器
interface 	SharedPreferences.OnSharedPreferenceChangeListener 	 当数据改变的时候调用
<!-- ========== METHOD SUMMARY =========== -->
Public Methods
abstract boolean 	contains (String key)   数据库里是否包含key的键值
abstract SharedPreferences.Editor 	edit ()      通过这个方法返回一个SharedPrefenences.Editor实例化对象
abstract Map <String , ?> 	getAll ()  返回所有的键值对,注意“?”,它代表你存储的数字类型,是泛型的用法
abstract boolean 	getBoolean (String key, boolean defValue) 通过key从Preferences获取boolean类型的数据
abstract float 	getFloat (String key, float defValue) 通过key从Preferences获取float类型的数据
abstract int 	getInt (String key, int defValue) 通过key从Preferences获取int类型的数据
abstract long 	getLong (String key, long defValue) 通过key从Preferences获取long类型的数据
abstract String 	getString (String key, String defValue) 通过key从Preferences获取String类型的数据
abstract void 	registerOnSharedPreferenceChangeListener (SharedPreferences.OnSharedPreferenceChangeListener listener)
注册一个监听器。当preferences数据改变的时候调用这个监听器下的方法
abstract void 	unregisterOnSharedPreferenceChangeListener (SharedPreferences.OnSharedPreferenceChangeListener listener)
注册一个监听器。取消先前注册的回调方法。



通过上面的editor() 方法就可以实例化SharedPreferences.Editor对象,接着就可以使用下面的一些方法进行存储。


Public Methods
abstract SharedPreferences.Editor 	

                                      
abstract boolean 	clear ()    删除所有值

commit ()   提交你设置的值
abstract SharedPreferences.Editor 	putBoolean (String key, boolean value)   设置boolean值存储
abstract SharedPreferences.Editor 	putFloat (String key, float value)  设置浮点型数据存储
abstract SharedPreferences.Editor 	putInt (String key, int value)  设置整形数据存储
abstract SharedPreferences.Editor 	putLong (String key, long value) 设置长整型
abstract SharedPreferences.Editor 	putString (String key, String value)  设置字符串数据存储
abstract SharedPreferences.Editor 	

remove (String key)  删除一个
 

SharedPreferences存储类效率分析

      SharedPreferences是Android平台上一个轻量级的存储类,主要是保存一些常用的配置比如窗口状态,一般在Activity中重载窗口状态onSaveInstanceState保存一般使用SharedPreferences完成,它提供了Android平台常规的Long长整形、Int整形、String字符串型的保存,它是什么样的处理方式呢?

SharedPreferences类似过去Windows系统上的ini配置文件,但是它分为多种权限,可以全局共享访问,android123提示最终是以xml方式来保存,整体效率来看不是特别的高,对于常规的轻量级而言比SQLite要好不少,如果真的存储量不大可以考虑自己定义文件格式。xml 处理时Dalvik会通过自带底层的本地XML Parser解析,比如XMLpull方式,这样对于内存资源占用比较好。



Android数据存取之Preferences

这种方式应该是用起来最简单的Android读写外部数据的方法了。他的用法基本上和 J2SE(java.util.prefs.Preferences)中的用法一样,以一种简单、透明的方式来保存一些用户个性化设置的字体、颜色、位置等参数信息。一般的应用程序都会提供“设置”或者“首选项”的这样的界面,那么这些设置最后就可以通过Preferences来保存,而程序员不需要知道它到底以什么形式保存的,保存在了什么地方。当然,如果你愿意保存其他的东西,也没有什么限制。只是在性能上不知道会有什么问题。

在Android系统中,这些信息以XML文件的形式保存在 /data/data/PACKAGE_NAME /shared_prefs 目录下。