(1)SharePreferences:

存入:  SharedPreferences setter = this.getSharedPreferences("spfile", 0);
            SharedPreferences.Editor editor = setter.edit();
            editor.putString("name", et.getText().toString());
            editor.putInt("age", 18);
            editor.putFloat("ID", 374892323);
            editor.commit();

读取: SharedPreferences getter = this.getSharedPreferences("spfile", 0);
           String st = getter.getString("name", "unknow");

SharePreferences方式在数据存储的格式上是采用的XML文件。

(2)FileInputStream and FileOutputStream:

采用的就是基础的Java.io方式读写文件。但是需要注意的是文件路径的写法。在Android上就不要再用 "///mnt/sdcard/data/a.txt"这种写法了。

最好是利用Environment类进行字符串的拼接。拼成完整的路径:

   String sdcardPath = null;
        String filePath = "jerei";
        String fileName="saveFile.txt";
        if( ! Environment.getExternalStorageState().equals(Environment.MEDIA_REMOVED)){
            sdcardPath = Environment.getExternalStorageDirectory().toString();
            filePath = sdcardPath+File.separator +filePath ;
            FileOutputStream fos = null;
            File fileDir = new File(filePath);
            if( ! fileDir.exists() ){
                fileDir.mkdirs();
            }

  fin = new FileInputStream(new File(filePath, fileName));

(3)SQLite 数据库:

对于SQLite数据库的操作主要依靠两个类:SQLiteDatabase 和 SQLiteOpenHelper

其中后者是一个抽象类,需要自己实现。

private class MySQLiteOpenHelper extends SQLiteOpenHelper {
        
        public MySQLiteOpenHelper(Context context, String name,
                CursorFactory factory, int version) {
            super(context, name, factory, version);
            // TODO Auto-generated constructor stub
        }
        public MySQLiteOpenHelper(Context context){
            this(context, DB_NAME, null, DB_VERSION);
        }

private static final String DB_NAME = "mydb.db";
        private static final int DB_VERSION = 1;
        public static final String NEWS_TAB="news";

@Override
        public void onCreate(SQLiteDatabase db) {
            // TODO Auto-generated method stub
            StringBuilder sb = new StringBuilder();
            sb.append("create table ");
            sb.append(NEWS_TAB);
            sb.append(" ( ");
            sb.append(" id integer primary key autoincrement ,  ");
            sb.append(" title varchar(100) , ");
            sb.append(" author varchar(100) ");
            sb.append(" ) ");
            db.execSQL(sb.toString());
        }

@Override
        public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
            // TODO Auto-generated method stub

}

}

而 SQLiteDataBase 则代表了一个数据库实例,可以通过自己实现 的sqliteOpenHelper类的 getWritableDatabase()方法和 getReadableDatabase()方法获得。

它包含操作数据库的具体方法。如:execSQL , delete ,query(返回一个Cursor类的对象) , update 等。

另外可以实现一个Dao来负责SQLite数据库的具体操作。

Android数据存储的三种方式:SharePreferences , file , SQLite的更多相关文章

  1. android 数据存储的几种方式

    总体的来讲,数据存储方式有三种:一个是文件,一个是数据库,另一个则是网络.其中文件和数据库可能用的稍多一些,文件用起来较为方便,程序可以自己定义格式:数据库用起稍烦锁一些,但它有它的优点,比如在海量数 ...

  2. android 数据存储的四种方式.

    Android系统一共提供了四种数据存储方式.分别是:SharePreference.SQLite.Content Provider和File.由于Android系统中,数据基本都是私有的的,都是存放 ...

  3. Android数据存储的五种方法汇总

    本文介绍Android中的5种数据存储方式. 数据存储在开发中是使用最频繁的,在这里主要介绍Android平台中实现数据存储的5种方式,分别是: 1 使用SharedPreferences存储数据 2 ...

  4. uni-app&H5&Android混合开发三 || uni-app调用Android原生方法的三种方式

    前言: 关于H5的调用Android原生方法的方式有很多,在该片文章中我主要简单介绍三种与Android原生方法交互的方式. 一.H5+方法调用android原生方法 H5+ Android开发规范官 ...

  5. 数据存储的两种方式:Cookie 和Web Storage

    数据存储的两种方式:Cookie 和Web Storage 1.Cookie Cookie的作用就像你去超市购物时,第一次给你办张购物卡,这个购物卡里存放了一些你的个人信息,下次你再来这个连锁超市时, ...

  6. 数据存储的两种方式:Cookie 和Web Storage(转)

    数据存储的两种方式:Cookie 和Web Storage   数据存储的两种方式:Cookie 和Web Storage 1.Cookie Cookie的作用就像你去超市购物时,第一次给你办张购物卡 ...

  7. PHP中数据类型转换的三种方式

    PHP中数据类型转换的三种方式 PHP的数据类型转换属于强制转换,允许转换的PHP数据类型有: 1.(int).(integer):转换成整形2.(float).(double).(real):转换成 ...

  8. Android数据存储的5种方法

    --使用SharedPreferences存储数据 --文件存储数据 --SQLite数据库存储数据 --使用ContentProvider存储数据 --网络存储数据 Preference,File, ...

  9. Android录制音频的三种方式

    对于录制音频,Android系统就都自带了一个小小的应用,可是使用起来可能不是特别的灵活.所以有提供了另外的俩种. 下边来介绍下这三种录制的方式; 1.通过Intent调用系统的录音器功能,然后在录制 ...

随机推荐

  1. Jquery.Datatables 导出excel

    按钮(Buttons) BUttons v1.1.2 下载地址:http://pan.baidu.com/s/1c0Jhckg JSZip v2.5.0-21-g4fd4fc1 下载地址:http:/ ...

  2. jQuery – 6.选择器

    1. 属性过滤选择器: 1. $("div[id]")选取有id属性的<div> 2. $("div[title=test]")选取title属性为 ...

  3. 重温WCF之发送和接收SOAP头(三)

    SOAP头可以理解为一种附加信息,就是附加到消息正文的内容. 既然消息头是附加信息,那有啥用呢?你可别说,有时候还真有不少用处.举个例子,WCF的身份验证是不是很麻烦?还要颁发什么证书的(当然不是荣誉 ...

  4. CXF学习 (1)

    Axis(Apache) -> Axis2(Apache) XFire - > CXF (XFire+Celtrix) (Apache) CXF并不仅仅是Webservice框架,更号称是 ...

  5. SSIS Dataflow使用存储过程不能检索列名

    在项目中遇到一个问题,需要在Dataflow中调用一个存储过程,然后把结果生成一个csv文件. 然而在dataflow调用存储过程中遇到了问题,SP不能正确的返回列名. 在SSMT里面明明是可以查出数 ...

  6. .NET NLog 详解(五) - Condition Expression

    Sample <!-- during normal execution only log Info messages --> <defaultFilter>level > ...

  7. WPF 创建自定义窗体

    在前面的一篇博客"WPF 自定义Metro Style窗体",展示了如何创建一个类似于Metro Style的Window,并在程序中使用.但是这个窗体不能够自由的改变大小.今天的 ...

  8. PMP 第十三章 项目干系人管理

    1.识别干系人是干什么?早期就识别干系人的原因是什么?识别干系人的输入和工具有哪些?干系人分析的几种模型是哪些?干系人登记册的内容有哪些?bbs.mypm.net 2.干系人参与程度的分类是怎样的?干 ...

  9. HorizontalScrollView

    HorizontalScrollView 链接

  10. PHP isset()与empty()的使用区别详解(转)

    通过对PHP语言的学习,应该知道它是基于函数的一款HTML脚本语言.庞大的函数库支持着PHP语言功能的实现.下面我们为大家介绍有关PHP函数isset()与empty()的相关用法.     PHP的 ...