【总结】Android攻城狮数据篇——SharedPreference

2024-02-26 21:58

本文主要是介绍【总结】Android攻城狮数据篇——SharedPreference,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Android攻城狮数据篇—SharedPreference

Android的四种数据存储方式:
  SharedPreference
  SQLite
  Content Provider
  File

SharedPreferences简介

  SharedPreferences对象本身只能获取数据而不支持存储和修改,存储修改是通过Editor对象实现。
实现Shared Preferences存储的步骤如下:
  (1)使用Activity类的getSharedPreferences方法获得
  SharedPreferences对象,其中存储key-value的文件的名称由getSharedPreferences方法的第一个参数指定。
  (2)使用SharedPreferences接口的edit获得SharedPreferences.Editor对象。
  (3)通过SharedPreferences.Editor接口的putXxx方法保存key-value对。其中XXX表示不同的数据类型。例如: 字符串类型的value需要用putString方法。
  (4)通过SharedPreferences.Edior接口的commit方法保存key-value对。commit方法相当于数据库事务中的提交(commit )操作。

具体实现代码

public class MainActivity extends AppCompatActivity {EditText put_name,put_word;CheckBox checkBox;SharedPreferences preferences;SharedPreferences.Editor editor;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);put_name = findViewById(R.id.put_name);put_word = findViewById(R.id.put_word);checkBox = findViewById(R.id.check);preferences = getSharedPreferences("myPref",MODE_PRIVATE);editor = preferences.edit();String name = preferences.getString("username","");if(name == null){checkBox.setChecked(false);}else{checkBox.setChecked(true);put_name.setText(name);}}public void DoClick(View view){switch (view.getId()){case R.id.login:String name = put_name.getText().toString().trim();String words = put_word.getText().toString().trim();if("admin".equals(name) &&"123456".equals(words)){if( checkBox.isChecked()){editor.putString("username", name);editor.putString("password",words);editor.commit();}else{editor.remove("username");editor.commit();}Toast.makeText(MainActivity.this, "登陆成功",Toast.LENGTH_SHORT).show();}else {Toast.makeText(MainActivity.this, "禁止登陆",Toast.LENGTH_SHORT).show();}break;;default:break;}}
}
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"tools:context="e.a17909.myapplication.MainActivity"><EditText
        android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_alignParentEnd="true"android:layout_alignParentRight="true"android:layout_alignParentTop="true"android:layout_toEndOf="@+id/username"android:layout_toRightOf="@+id/username"android:id="@+id/put_name" /><EditText
        android:id="@+id/put_word"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_alignParentEnd="true"android:layout_alignParentRight="true"android:layout_below="@+id/put_name"android:layout_toEndOf="@+id/password"android:layout_toRightOf="@+id/password" /><TextView
        android:id="@+id/username"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_alignBaseline="@+id/put_name"android:layout_alignBottom="@+id/put_name"android:layout_alignParentLeft="true"android:layout_alignParentStart="true"android:text="用户名" /><TextView
        android:id="@+id/password"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_alignBaseline="@+id/put_word"android:layout_alignBottom="@+id/put_word"android:layout_alignParentLeft="true"android:layout_alignParentStart="true"android:layout_toLeftOf="@+id/put_name"android:layout_toStartOf="@+id/put_name"android:text="密    码" /><CheckBox
        android:id="@+id/check"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_alignParentLeft="true"android:layout_alignParentStart="true"android:layout_below="@+id/put_word"android:text="记住用户名" /><Button
        android:id="@+id/login"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_alignParentLeft="true"android:layout_alignParentStart="true"android:onClick="DoClick"android:layout_below="@+id/check"android:text="登陆" /><Button
        android:id="@+id/cancel"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_alignBaseline="@+id/login"android:layout_alignBottom="@+id/login"android:layout_toEndOf="@+id/login"android:layout_toRightOf="@+id/login"android:text="取消" /></RelativeLayout>

这篇关于【总结】Android攻城狮数据篇——SharedPreference的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/750285

相关文章

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

Android ClassLoader加载机制详解

《AndroidClassLoader加载机制详解》Android的ClassLoader负责加载.dex文件,基于双亲委派模型,支持热修复和插件化,需注意类冲突、内存泄漏和兼容性问题,本文给大家介... 目录一、ClassLoader概述1.1 类加载的基本概念1.2 android与Java Class

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys

SQL中如何添加数据(常见方法及示例)

《SQL中如何添加数据(常见方法及示例)》SQL全称为StructuredQueryLanguage,是一种用于管理关系数据库的标准编程语言,下面给大家介绍SQL中如何添加数据,感兴趣的朋友一起看看吧... 目录在mysql中,有多种方法可以添加数据。以下是一些常见的方法及其示例。1. 使用INSERT I

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

JavaSE正则表达式用法总结大全

《JavaSE正则表达式用法总结大全》正则表达式就是由一些特定的字符组成,代表的是一个规则,:本文主要介绍JavaSE正则表达式用法的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录常用的正则表达式匹配符正则表China编程达式常用的类Pattern类Matcher类PatternSynta

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查

python实现对数据公钥加密与私钥解密

《python实现对数据公钥加密与私钥解密》这篇文章主要为大家详细介绍了如何使用python实现对数据公钥加密与私钥解密,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录公钥私钥的生成使用公钥加密使用私钥解密公钥私钥的生成这一部分,使用python生成公钥与私钥,然后保存在两个文

mysql中的数据目录用法及说明

《mysql中的数据目录用法及说明》:本文主要介绍mysql中的数据目录用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、版本3、数据目录4、总结1、背景安装mysql之后,在安装目录下会有一个data目录,我们创建的数据库、创建的表、插入的