- SharedPreferences
- SQLiteOpenHelper
- Timer定时器
1.SharedPreferences偏好
偏好的几种模式
Context.MODE_PRIVATE: 指定该SharedPreferences数据只能被本应用程序读、写;
Context.MODE_WORLD_READABLE: 指定该SharedPreferences数据能被其他应用程序读,但不能写;
Context.MODE_WORLD_WRITEABLE: 指定该SharedPreferences数据能被其他应用程序读;
Context.MODE_APPEND:该模式会检查文件是否存在,存在就往文件追加内容,否则就创建新文件
存储数据:
//步骤1:创建一个SharedPreferences对象
SharedPreferences sharedPreferences
= getSharedPreferences("data", Context.MODE_PRIVATE);
//步骤2: 实例化SharedPreferences.Editor对象
SharedPreferences.Editor editor = sharedPreferences.edit();
//步骤3:将获取过来的值放入文件
editor.putString("name", "张三");
editor.putInt("age", 28);
editor.putBoolean("isStudent",false);
//步骤4:提交
editor.commit();
//注意如果不在Activity里面获取偏好
那么需要context.getSharedPreferences("data", Context.MODE_PRIVATE);
获取数据:
SharedPreferences sharedPreferences= getSharedPreferences("data", Context .MODE_PRIVATE);
String userName=sharedPreferences.getString("name","");
删除指定数据
editor.remove("name");
editor.commit();
清空数据
editor.clear();
editor.commit();
2.SQLiteOpenHelper SQLLite数据库
https://blog.csdn.net/zhangfei8625/article/details/44410143
写一个类 继承与SQLiteOpenHelper,并重写onCreate()和onUpgrade(),必须要有构造函数,SQLiteOpenHelper构造方法中,四个参数分别表示context 上下文对象,name 初始化数据库名称,factory CursorFactory对象,version 数据库版本,默认是1,版本变化会执行回调函数onUpgrade()方法!
数据库代码(创建数据库):
public final String CAREA_TABLE = "User";
public final String CAREATE_CAREA_TABLE_SQL = "CREATE TABLE " + CAREA_TABLE + "("
+ "UserId INTEGER,"
+ "UserName varchar(30),"
+ "UserAge INTEGER"
+ ");";
//必须要有的构造函数
public MyDBHelper(@Nullable Context context, @Nullable String name, @Nullable SQLiteDatabase.CursorFactory factory, int version) {
super(context, name, factory, version);
}
// 当第一次创建数据库的时候,调用该方法
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL(CAREATE_CAREA_TABLE_SQL);
Log.e("create","数据库创建成功");
}
//当更新数据库的时候执行该方法
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
//输出更新数据库的日志信息
Log.i("onUpgrade", "update Database------------->");
}
增查代码:
public static int count=0;
private MyDBHelper dbHelper;
private SQLiteDatabase db;
public void insert(){
count++;
String name="用户"+count;
int age=count;
dbHelper=new MyDBHelper(MainActivity.this,"User",null,1);
db=dbHelper.getWritableDatabase();
ContentValues cv =new ContentValues();
cv.put("UserId",count);
cv.put("UserName",name);
cv.put("UserAge",count);
db.insert("User",null,cv);
db.close();
}
private void queryDB(){
dbHelper=new MyDBHelper(MainActivity.this,"User",null,1);
SQLiteDatabase db=dbHelper.getReadableDatabase();
Cursor cursor=db.query("user", null, null, null, null, null, null);
while(cursor.moveToNext()){
int id=cursor.getInt(cursor.getColumnIndex("UserId"));
String name=cursor.getString(cursor.getColumnIndex("UserName"));
int age=cursor.getInt(cursor.getColumnIndex("UserAge"));
Log.e("sele",id+" "+name+" "+age);
}
db.close();
}
3.Timer定时器
https://www.cnblogs.com/fuyunmomo/p/4272743.html
Timer是一种定时器工具,用来在一个后台线程计划执行指定任务。它可以计划执行一个任务一次或反复多次。
TimerTask一个抽象类,它的子类代表一个可以被Timer计划的任务。
第一步,得到Timer的实例化对象
Timer timer= new Timer() ;
第二步,实例化TimerTask对象
TimerTask timerTask = new TimerTask(){
publicvoid run(){
//Doing something
}
}
实例化TimerTask对象的时候,需要重写它的run()方法,然后在这个方法体内增加需要执行的具体操作。比如 输出一句话,发送一个消息之类的。
第三步,启动定时器
Timer.schedule(TimerTask, delay, period) ;
第一个参数,任务,第二个参数,延时多久执行,第三个参数,每隔多久执行
timer.cancel();取消任务