Android数据持久化之Preferences机制详解

本文实例讲述了Android数据持久化之Preferences机制。分享给大家供大家参考,具体如下:

在Android中,实现数据持久化有五种方式:Preferences,文件File,I/O操作、SQLite数据库,ContentProvider组件。

下面逐个做一简单的介绍:

一、Preferences的介绍:

Preferences是一种轻量级的数据存储机制,他将一些简单的数据类型的数据,包括boolean类型,int类型,float类型,long类型以及String类型的数据,以键值对的形式存储在应用程序的私有Preferences目录(/data/data/<包名>/shared_prefs/)中,这种Preferences机制广泛应用于存储应用程序中的配置信息。

如下是Preferences的一个简单代码:

这个代码是创建不同权限的数据对象:

package com.example.data_sharedpreferences; import android.os.Bundle; import android.app.Activity; import android.content.Context; import android.content.SharedPreferences; import android.view.Menu; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.TextView; public class MainActivity extends Activity { private TextView text; private Button button; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); // 写入数据 writeData(); text = (TextView) findViewById(R.id.text); button = (Button) findViewById(R.id.button0); button.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { // TODO Auto-generated method stub // 读取数据 readData(); } }); } /** * 写入数据 */ public void writeData() { // 设置权限为私有MODE_PRIVATE SharedPreferences sp_p = this.getSharedPreferences("ct_sp_private", Context.MODE_PRIVATE); // 通过SharedPreferences对象的编辑器对象Editor来实现存入数据 SharedPreferences.Editor editor = sp_p.edit(); // 通过该编辑器函数设置键值 editor.putString("username", "marry_private"); // 提交数据,并将数据写入xml文件中 editor.commit(); // 设置为只读 SharedPreferences sp_or = this.getSharedPreferences("ct_sp_private", Context.MODE_WORLD_READABLE); sp_or.edit().putString("username", "marry_only_read").commit(); // 设置为只写 SharedPreferences sp_ow = this.getSharedPreferences("ct_sp_private", Context.MODE_WORLD_WRITEABLE); sp_ow.edit().putString("username", "marry_only_write").commit(); // 设置为可读可写 SharedPreferences sp_x = this.getSharedPreferences("ct_sp_private", Context.MODE_WORLD_READABLE + Context.MODE_WORLD_WRITEABLE); sp_x.edit().putString("username", "marry_write_read").commit(); } /** * 读取数据 * 通过SharedPreferences对象的键key可以获取到对应key的键值value。对于不同类型的键值有不同的函数:getBoolean * ,getInt,getFloat,getLong. */ public void readData() { // TODO Auto-generated method stub text.setText("private_username:" + this.getSharedPreferences("ct_cp_private", 0).getString( "username", "marry_private") + "\r\n" + "read_username:" + this.getSharedPreferences("ct_cp_private", 0).getString( "username", "marry_only_read") + "\r\n" + "write_username:" + this.getSharedPreferences("ct_cp_private", 0).getString( "username", "marry_only_write") + "\r\n" + "write_read_username:" + this.getSharedPreferences("ct_cp_private", 0).getString( "username", "marry_write_read") + "\r\n"); } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); return true; } }

下面这个代码则是实现在另外一个应用中访问上一个应用,并读取上面应用的数据:

package com.example.data_sharedpreferences2; import com.example.data_sharedpreferences2.R; import android.os.Bundle; import android.app.Activity; import android.content.Context; import android.content.pm.PackageManager.NameNotFoundException; import android.view.Menu; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.TextView; /** * 该程序的功能是访问data_sharedpreferences应用 Sharedpreferences访问另一个应用的条件: * 1、被访问的应用权限为可读或者可写 2、必须要知道被访问应用的包名 * * @author marry * */ public class MainActivity extends Activity { private TextView text; private Button button; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); text = (TextView) findViewById(R.id.text); button = (Button) findViewById(R.id.button0); button.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { // 访问应用1,并读取应用1的数据 try { // 获得要访问应用的context Context ortherContext = createPackageContext( "com.example.data_sharedpreferences", 0); // 通过ortherContext.getSharedPreferences打开应用1的文件 text.setText("private_username:" + ortherContext.getSharedPreferences( "ct_cp_private", 0).getString("username", "marry_private") + "\r\n" + "read_username:" + ortherContext.getSharedPreferences( "ct_cp_private", 0).getString("username", "marry_only_read") + "\r\n" + "write_username:" + ortherContext.getSharedPreferences( "ct_cp_private", 0).getString("username", "marry_only_write") + "\r\n" + "write_read_username:" + ortherContext.getSharedPreferences( "ct_cp_private", 0).getString("username", "marry_write_read") + "\r\n"); } catch (NameNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }); } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); return true; } }

使用Preferences时有以下需要注意的地方:

1、 通过Context.getSharedPreferences(String fileName,int mode)方法,可以打开一个xml文件,文件的位置在/data/data/package_name/shared_prefs/fileName.xml,如果不存在,则会自动创建。可以对该文件进行读写操作,在应用内的各组件之间共享数据。如果将mode设置为Context.MODE_WORLD_READ或者Context.MODE_WORLD_WRITE,则还可以被其他应用访问到。不过这不是android推荐的方式,要实现跨应用共享数据,推荐的方式是用ContentProvider实现

2、 如果要访问另一个应用创建的shared_prefs文件,需要满足2个条件,首先另一个应用要设置MODE_WORLD_READ或MODE_WORLD_WIRTE权限,并且要知道另一个应用的package_name,然后就可以通过Context.createPackageContext()方法,就可以得到另一个应用的context,然后context.getSharedPreferences()方法,就可以打开shared_prefs文件了。不过这种方法并不推荐

3、 在罕见的情况下,如果既把shared_prefs的权限设置为MODE_PRIVATE,又希望某些其他的应用可以访问到,那么可以在manifest文件中配置android:user_id(好像是这个属性),让多个应用共享USER_ID。因为本质上shared_prefs文件是采用linux的权限控制的,MODE_PRIVATE类似于-rw-------,所以如果多个应用使用了同一个USER_ID,自然都对这个文件有访问权限了

更多关于Android相关内容感兴趣的读者可查看本站专题:《Android数据库操作技巧总结》、《Android编程之activity操作技巧总结》、《Android文件操作技巧汇总》、《Android编程开发之SD卡操作方法汇总》、《Android开发入门与进阶教程》、《Android资源操作技巧汇总》、《Android视图View技巧总结》及《Android控件用法总结》

希望本文所述对大家Android程序设计有所帮助。

时间: 2024-09-24 23:45:09

Android数据持久化之Preferences机制详解的相关文章

Android数据持久化之ContentProvider机制详解

本文实例讲述了Android数据持久化之ContentProvider机制.分享给大家供大家参考,具体如下: 一般而言,android操作系统的应用程序所建立的数据只允许自己使用,应用程序彼此间无法借助公用存储器来共享数据,android系统提供了一个机制,即内容提供器(ContentProvider),来公开自己私有的数据到数据内容器,通过该机制,可以供其他应用程序来读取自己内部的数据,当然也可以访问其他应用程序的数据.通常,内容提供器背后都有SQLite数据库的支持,用以存储内容提供内部数据

Android数据持久化之File机制分析

本文实例讲述了Android数据持久化之File机制.分享给大家供大家参考,具体如下: 在使用Java SE平台开发C/S结构的软件中,File 的IO输入输出流的使用率是非常高的,通过使用IO输入输出流可以对存储介质上的文件进行读写操作,下面的代码就是实现一个在Android平台上使用File对象操作文件的功能: package com.example.data_file; import java.io.File; import java.io.FileInputStream; import

Android开发之触摸事件处理机制详解

android触碰消息传递机制 用户的每次触碰(onClick,onLongClick,onScroll,etc.)都是由一个ACTION_DOWN+n个ACTION_MOVE+1个ACTION_UP组成的,用户触碰必先有个ACTION_DOWN响应,用户触碰结束必然会有个ACTION_UP.(当然如果在途中被拦截,就可能不会有了!)那么View是如何分发消息和拦截消息呢? 1.View及其子类都会有的两个方法: public boolean dispatchTouchEvent(MotionE

iOS数据持久化-SQLite数据库使用详解

使用SQLite数据库 创建数据库 创建数据库过程需要3个步骤: 1.使用sqlite3_open函数打开数据库: 2.使用sqlite3_exec函数执行Create Table语句,创建数据库表: 3.使用sqlite3_close函数释放资源. 这个过程中使用了3个SQLite3函数,它们都是纯C语言函数,通过Objective-C去调用C函数当然不是什么问题,但是也要注意Objective-C数据类型与C数据类型兼容性问题. 下面我们使用SQLite技术实现备忘录案例,与属性列表文件实现

Android数据持久化之读写SD卡中内容的方法详解

本文实例讲述了Android数据持久化之读写SD卡中内容的方法.分享给大家供大家参考,具体如下: 前面文章里讲的那三个方法:openFileOutput .openFileInput 虽然都能通过流对象OutputStream和InputStream可以处理任意文件中的数据,但与 SharedPreferences 一样,只能在手机内存的指定目录下建立文件,因此,在实际的开发使用中有很大的局限性,那么在这一节中,我们来看一个比较高级的方法来实现数据的持久化--读写SD卡上的内容. --读取ass

Android数据持久化之I/O操作详解

本文实例讲述了Android数据持久化之I/O操作.分享给大家供大家参考,具体如下: 前面文章里我们简单的介绍了File的操作,这一节来说说使用android平台自带对象实现文件的基本操作 主要的两个类:openFileOutput(写)和openFileInput(读) 向文件中写如数据代码如下: //向文件写入内容 try { OutputStream os = openFileOutput("file-io.txt", Context.MODE_PRIVATE); String

ActiveMQ消息传送机制以及ACK机制详解 AcitveMQ是作为一种消息存储和分发组件,涉及到client与broker端数据交互的方方面面,它不仅要担保消息的存储安全性,还要提供额外的

ActiveMQ消息传送机制以及ACK机制详解     AcitveMQ是作为一种消息存储和分发组件,涉及到client与broker端数据交互的方方面面,它不仅要担保消息的存储安全性,还要提供额外的手段来确保消息的分发是可靠的.   一. ActiveMQ消息传送机制     Producer客户端使用来发送消息的, Consumer客户端用来消费消息:它们的协同中心就是ActiveMQ broker,broker也是让producer和consumer调用过程解耦的工具,最终实现了异步RPC

Android事件的分发机制详解_Android

在分析Android事件分发机制前,明确android的两大基础控件类型:View和ViewGroup.View即普通的控件,没有子布局的,如Button.TextView. ViewGroup继承自View,表示可以有子控件,如Linearlayout.Listview这些.今天我们先来了解View的事件分发机制. 先看下代码,非常简单,只有一个Button,分别给它注册了OnClick和OnTouch的点击事件. btn.setOnClickListener(new View.OnClick

数据-java中android中onTouchEvent方法的问题详解,谢谢解答!

问题描述 java中android中onTouchEvent方法的问题详解,谢谢解答! public boolean onTouchEvent(MotionEvent event) { //调用warp方法根据触摸屏事件的座标点来扭曲verts数组 warp(event.getX(), event.getY()); return true; } //MotionEvent event这两个哪个是数据类型,哪个是数值 //event.getX(), event.getY() 返回的是什么值是什么数