0
点赞
收藏
分享

微信扫一扫

Android-第十三节02SharedPreferences详解

E_topia 2022-04-13 阅读 24
javaandroid

文章目录


一、SharedPreferences概述

SharedPreferences是Android平台上一个轻量级的存储辅助类,用来保存应用的一些常用配置,它提供了string,set, int, long, float, boolean六种数据类型。最终数据是以xm1形式进行存储。在应用中通常做一些简单数据的持久化缓存。

下面举一个sp应用的场景

在这里插入图片描述

二、SharedPreferences的使用方法

因为sp是存储在data/data/包名目录下的,所以我们不需要动态申请权限
1.添加button并添加点击事件
在这里插入图片描述
在这里插入图片描述
核心代码

button.findViewById(R.id.button);
        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                
            }
        });

2.1写数据

1.activity代码(拿到SharedPreferences,再添加数据)

package com.hnucm.a_test13;

import androidx.appcompat.app.AppCompatActivity;

import android.content.SharedPreferences;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.Reader;

public class MainActivity extends AppCompatActivity {
    Button button;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        button=findViewById(R.id.button);
        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                SharedPreferences sharedPreferences=getSharedPreferences("user",MODE_PRIVATE);//拿到 sharedPreferences 的引用 MODE_PRIVATE表示只能被本应用读写,不能被其他应用读写
                SharedPreferences.Editor editor=sharedPreferences.edit();//拿到编辑对象
                editor.putBoolean("isLogin",true);//添加数据
                editor.commit();

            }
        });
    }
}

2.运行,点击按钮,刷新一下data/data/包名目录,会发现我们的数据被保存到了一个文件夹
在这里插入图片描述

2.2读数据

1.核心代码

package com.hnucm.a_test13;

import androidx.appcompat.app.AppCompatActivity;

import android.content.SharedPreferences;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.Toast;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.Reader;

public class MainActivity extends AppCompatActivity {
    Button button;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        button=findViewById(R.id.button);
        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                SharedPreferences sharedPreferences=getSharedPreferences("user",MODE_PRIVATE);//拿到 sharedPreferences 的引用 MODE_PRIVATE表示只能被本应用读写,不能被其他应用读写
                boolean isLogin = sharedPreferences.getBoolean("isLogin", false);//当key不存在时,默认返回defValue的值
                Log.i("MainActivity","isLogin "+isLogin);
                Toast.makeText(MainActivity.this,""+isLogin,Toast.LENGTH_SHORT).show();
            }
        });
    }
}

2.运行结果
在这里插入图片描述

三、SharedPreferences案例-qq登录demo

3.1第一步,创建activity

我们需要先创建三个activity

在这里插入图片描述

在这里插入图片描述
1.默认第一个见到的页面是MainActivity,我们需要把LaunchActivity设置为我们第一个见到的activity
在这里插入图片描述
2.并且去掉应用的标题框
在这里插入图片描述

3.2第二步,设置启动跳转页面

1.给启动跳转页面设置背景图片(图片如下)
在这里插入图片描述

在这里插入图片描述
2.并且设置延时跳转(需要判断用户是否登录过)
在这里插入图片描述
3.LaunchActivity代码

package com.hnucm.a_test13;

import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;

import android.annotation.SuppressLint;
import android.content.Intent;
import android.content.SharedPreferences;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;


public class LaunchActivity extends AppCompatActivity {
    @SuppressLint("HandlerLeak")
    Handler mHandler=new Handler(){
        @Override
        public void handleMessage(@NonNull Message msg) {
            super.handleMessage(msg);


            SharedPreferences sharedPreferences= getSharedPreferences("user", MODE_PRIVATE);
            boolean islogin = sharedPreferences.getBoolean("islogin",false);//如果读不到文件或者当key不存在时 返回false


            //判断用户是否登录过

            if (islogin) {  //如果登录过 跳转到 MainActivity

                Intent intent=new Intent(LaunchActivity.this,MainActivity.class);
                startActivity(intent);
            }else { //如果没有登录过 跳转到 LoginActivity
                Intent intent=new Intent(LaunchActivity.this,LoginActivity.class);
                startActivity(intent);
            }
        }
    };

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_launch);

        mHandler.sendEmptyMessageDelayed(1,3000);//3秒后发送消息

    }
}

4.运行结果
在这里插入图片描述

3.3第三步,设置登录界面

1.(简单设置一下)
在这里插入图片描述
核心代码

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout 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=".LoginActivity">

    <TextView
        android:id="@+id/textView2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="148dp"
        android:text="这是登录界面"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <Button
        android:id="@+id/button2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="124dp"
        android:text="登录"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/textView2" />
</androidx.constraintlayout.widget.ConstraintLayout>

2.再到LoginActivity,设置登录界面点击按钮返回登录状态到文件
在这里插入图片描述
核心代码

package com.hnucm.a_test13;

import androidx.appcompat.app.AppCompatActivity;

import android.content.Intent;
import android.content.SharedPreferences;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;

public class LoginActivity extends AppCompatActivity {
    Button button;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_login);
        button=findViewById(R.id.button2);
        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                //点击按钮 代表登录成功
                //获取SharedPreferences对象
                SharedPreferences sharedPreferences=getSharedPreferences("user",MODE_PRIVATE);
                //获取Editor对象的引用
                SharedPreferences.Editor editor=sharedPreferences.edit();
                //将登录的状态放入文件
                editor.putBoolean("islogin",true);
                editor.putString("username","dd");
                //提交数据
                editor.commit();
                Intent intent=new Intent(LoginActivity.this,MainActivity.class);
                startActivity(intent);
            }
        });
    }
}

3.主界面页面
在这里插入图片描述
MainActivity代码

package com.hnucm.a_test13;

import androidx.appcompat.app.AppCompatActivity;

import android.content.SharedPreferences;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.Toast;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.Reader;

public class MainActivity extends AppCompatActivity {
    Button button;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        SharedPreferences sharedPreferences= getSharedPreferences("user", MODE_PRIVATE);
        String username=sharedPreferences.getString("username","不存在");
        Toast.makeText(MainActivity.this,""+username,Toast.LENGTH_SHORT).show();

    }
}

3.4存在的两个问题

问题一

主界面点击返回,会返回到上一个页面并不会直接退出

1.在LaunchActivity中加入finsh方法
在这里插入图片描述
2.在LoginActivity中也加入finish方法
在这里插入图片描述

3.点击运行看最终结果
在这里插入图片描述

问题二

每次进入程序会有一小段时间 程序出现空白页面
1.问题分析:
在这里插入图片描述
2.解决方案:自定义主题
在这里插入图片描述

<style name="Theme.A_Test13" parent="Theme.MaterialComponents.DayNight.NoActionBar">
        <item name= "android:windowNoTitle">true</item>//无标题.
        <item name= "android:windowFullscreen">true</item>//全屏即无通知栏
        <item name="android:windowContentOverlay" >@null</item>//是否有遮盖
        <item name="android:windowBackground" >@drawable/qq</item>
    </style>

3.然后在mainifests给第一个界面定义主题
在这里插入图片描述
4.运行(会有明显改善)
在这里插入图片描述
本讲关于SharedPreferences的知识就讲到这里啦,是不是又掌握了一个小技巧,谢谢您的阅读

举报

相关推荐

0 条评论