Android:数据持久化、Environment、SharedPreferences、内部存储internalStorage

简介:

1.数据持久化-SDCard

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
//数据持久化-SDCard
findViewById(R.id.button1).setOnClickListener( new  OnClickListener()
{
     @Override
     public  void  onClick(View v)
     {
         //判断SDCard是否正常加载
         if (Environment.MEDIA_MOUNTED.equals(Environment.getExternalStorageState()))
         {
             //获取SDCard根目录
             File sdcardPath = Environment.getExternalStorageDirectory();
             //获取SDCard可用空间
             long  freeSpace = sdcardPath.getFreeSpace();
             Log.e( "space" , freeSpace +  "" );
         }
     }
});



2.SharedPreferences:(data/data/包名/shared_prefs/)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
private  void  btn2Click()
     {
        // SharedPreferences sp = getPreferences(0);
         SharedPreferences sp = getSharedPreferences( "filename" , MODE_PRIVATE); //私有模式
         String str = sp.getString( "value" "noread" );
         boolean  bol = sp.getBoolean( "flag" true );
         textView.setText(str +  " "  + bol);
     }
     private  void  btn1Click()
     {
//        SharedPreferences sp = getPreferences(MODE_WORLD_READABLE | MODE_WORLD_WRITEABLE);//全局可读可写
         SharedPreferences sp = getSharedPreferences( "filename" , MODE_APPEND); //指定文件名,(内容)追加模式
         Editor editor = sp.edit();
         String value = editText.getText().toString();
         editor.putString( "value" , value);
         editor.putBoolean( "flag" false );
         editor.commit();
     }


3.内部存储internalStorage:(data/data/包名/files/)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
private  void  btn2Click()
     {
         try
         {
             FileInputStream fis = openFileInput( "fos1.txt" ); //读取文件
                 
             int  length =  0 ;
             byte [] buffer =  new  byte [ 1024 ];
             while (- 1  != (length = fis.read(buffer)))
             {
                 textView.setText( new  String (buffer, 0 ,length));
             }
         }
         catch  (FileNotFoundException e)
         {
             e.printStackTrace();
         }
         catch  (IOException e)
         {
             e.printStackTrace();
         }
             
             
     }
     private  void  btn1Click()
     {
         FileOutputStream fos =  null ;
         try
         {
             fos = openFileOutput( "fos1.txt" ,MODE_PRIVATE); //写入文件
             String str = editText.getText().toString();
             fos.write(str.getBytes());
             fos.flush();
         }
         catch  (FileNotFoundException e)
         {
             e.printStackTrace();
         }
         catch  (IOException e)
         {
             e.printStackTrace();
         }
         finally
         {
             if null  != fos )
             {
                 try
                 {
                     fos.close();
                 }
                 catch  (IOException e)
                 {
                     e.printStackTrace();
                 }
             }
         }
     }






本文转自 glblong 51CTO博客,原文链接:http://blog.51cto.com/glblong/1215469,如需转载请自行联系原作者
目录
相关文章
|
26天前
|
开发框架 前端开发 Android开发
Flutter 与原生模块(Android 和 iOS)之间的通信机制,包括方法调用、事件传递等,分析了通信的必要性、主要方式、数据传递、性能优化及错误处理,并通过实际案例展示了其应用效果,展望了未来的发展趋势
本文深入探讨了 Flutter 与原生模块(Android 和 iOS)之间的通信机制,包括方法调用、事件传递等,分析了通信的必要性、主要方式、数据传递、性能优化及错误处理,并通过实际案例展示了其应用效果,展望了未来的发展趋势。这对于实现高效的跨平台移动应用开发具有重要指导意义。
105 4
|
4月前
|
开发工具 Android开发 开发者
Android平台如何不推RTMP|不发布RTSP流|不实时录像|不回传GB28181数据时实时快照?
本文介绍了一种在Android平台上实现实时截图快照的方法,尤其适用于无需依赖系统接口的情况,如在RTMP推送、RTSP服务或GB28181设备接入等场景下进行截图。通过底层模块(libSmartPublisher.so)实现了截图功能,封装了`SnapShotImpl.java`类来管理截图流程。此外,提供了关键代码片段展示初始化SDK实例、执行截图、以及在Activity销毁时释放资源的过程。此方案还考虑到了快照数据的灵活处理需求,符合GB/T28181-2022的技术规范。对于寻求更灵活快照机制的开发者来说,这是一个值得参考的设计思路。
|
6月前
|
XML 存储 JSON
51. 【Android教程】JSON 数据解析
51. 【Android教程】JSON 数据解析
161 2
|
6月前
|
存储 API 文件存储
47. 【Android教程】SharedPreferences 存储
47. 【Android教程】SharedPreferences 存储
71 2
|
7月前
|
数据库 Android开发
Android 通过升级SettingsProvider数据强制覆盖用户的设置项
Android 通过升级SettingsProvider数据强制覆盖用户的设置项 【5月更文挑战第7天】
202 5
|
2月前
|
存储 大数据 数据库
Android经典面试题之Intent传递数据大小为什么限制是1M?
在 Android 中,使用 Intent 传递数据时存在约 1MB 的大小限制,这是由于 Binder 机制的事务缓冲区限制、Intent 的设计初衷以及内存消耗和性能问题所致。推荐使用文件存储、SharedPreferences、数据库存储或 ContentProvider 等方式传递大数据。
88 0
|
4月前
|
存储 安全 API
Android经典实战之存储方案对比:SharedPreferences vs MMKV vs DataStore
本文介绍了 Android 开发中常用的键值对存储方案,包括 SharedPreferences、MMKV 和 DataStore,并对比了它们在性能、并发处理、易用性和稳定性上的特点。通过实际代码示例,帮助开发者根据项目需求选择最适合的存储方案,提升应用性能和用户体验。
135 1
|
4月前
|
JSON Java Android开发
Android 开发者必备秘籍:轻松攻克 JSON 格式数据解析难题,让你的应用更出色!
【8月更文挑战第18天】在Android开发中,解析JSON数据至关重要。JSON以其简洁和易读成为首选的数据交换格式。开发者可通过多种途径解析JSON,如使用内置的`JSONObject`和`JSONArray`类直接操作数据,或借助Google提供的Gson库将JSON自动映射为Java对象。无论哪种方法,正确解析JSON都是实现高效应用的关键,能帮助开发者处理网络请求返回的数据,并将其展示给用户,从而提升应用的功能性和用户体验。
110 1
|
4月前
|
缓存 API Android开发
Android经典实战之Kotlin Flow中的3个数据相关的操作符:debounce、buffer和conflate
本文介绍了Kotlin中`Flow`的`debounce`、`buffer`及`conflate`三个操作符。`debounce`过滤快速连续数据,仅保留指定时间内的最后一个;`buffer`引入缓存减轻背压;`conflate`仅保留最新数据。通过示例展示了如何在搜索输入和数据流处理中应用这些操作符以提高程序效率和用户体验。
57 6
|
4月前
|
编解码 网络协议 前端开发
如何实现Android平台GB28181设备接入模块按需打开摄像头并回传数据
后台采集摄像头,如果想再进一步扩展,可以把android平台gb28181的camera2 demo,都移植过来,实现功能更强大的国标设备侧,这里主要是展示,收到国标平台侧的回传请求后,才打开摄像头,才开始编码打包,最大限度的减少资源的占用