zoukankan      html  css  js  c++  java
  • 浅谈android组件间的值传递

    浅谈android组件间的值传递

    • 导言
    • 5种类型的的简要示例
    • 讨论

    导言

    以前,没怎么认真思考过android的组件间的传值,都是秉承着,设置用shared来存,缓存用文件来存,复杂数据用sqlite,简单的数据之间设置intent,最近,做的一个项目让我认真的思考了一下,我们该如何更方便的处理我们的数据?

    5种类型的的简要示例

    假设有这么一个流程

    A组件 把值传递给 B组件

    内存

    1. A -> parcel/serializable <- B

      A 利用android的序列化机制,传递值的状态,使B能够通过KEY 获取到A 改变的值.

    2. A -> Application <- B

      A 利用Application定义的全局变量,进行值的修改,B通过变量访问Application的值.

    文件

    1. A -> sharedpreference <- B

      A 在sharedprefernce 里面更改值,B通过KEY值获取A改变的值

    2. A -> File <- B

      A 把值写进文件里面,B通过文件名获取A的值

    3. A -> SQlite <- B

      A 通过数据库的操作把值存进去,B同样通过数据库操作获得

    讨论

    对于这5种类型,我以存储的介质,简单做了一个分类,那我们应该怎么对组件间的传值进行一个最优选择呢?

    还记得,我们最开始学习android的时候,老师都是这么教的

    `Intent intent = new Intent().setClass(xxxx)

    context.startxxxx `

    之后我们的目标类就可以通过获得intent这个包,接着用相应的key获取到相应的值.

    现在,我们来思考一下这种传值模式.这个模型是一个传递模型,即是一个一对一的传递,如果,我们的关系只有A 组件 到 B 组件,然后B组件到C 组件的话,值的的存在状态只有A 到B,然后B 到 C 传的值是一个全新的状态的话,这种传值模式是非常的简便而且高效.

    但是,这种模式不利于处理值的状态传递.如果,有这么一个需要,C要读取A发出的值,A的值需要通过B进行处理发给C

    A -> B -> C

    看上去一点问题都没,但是,通过B 处理的值,C只能接受一次,因为,B传递给C值是一个全新的值,并不是真正的有A那里获取,所以下次要从A获取同样的值,就又要处理一遍,我们可以想象,能够组件关系多了的话这个处理就有多复杂了.这里,我们就会思考,找个地方把值存起来吧.

    值的存储形式

    对于android的值的保存,我们可以有如下选择

    • Application
    • Sharedpreference
    • File
    • SQlite

    那么,接下来,我们思考的就是应该以文件的方式存,还是直接把值存到应用的整个周期里面.

    值的生命周期

    然后,我们需要思考的是我们的值需要存储多久?

    • Application 整个应用程序的存在
    • Sharedpreference 一直存在,直到清除
    • File 一直存在,直到清除
    • SQlite 一直存在,直到清除

    值的操作

    确定了值的存储的周期以后,我们接下来要考虑的就是对于操作

    • Application 通过静态变量
    • Sharedpreference 通过系统的shared框架,用key-value进行值的CURD
    • File 通过文件名
    • SQlite 通过数据库操作

    待续...

    下一讲,结合例子比较...

  • 相关阅读:
    Java语言
    包名规范
    带参数的方法
    成员变量和局部变量
    Java数据类型
    java反射机制
    JDK安装
    注释
    二维数组
    数组的经典排序
  • 原文地址:https://www.cnblogs.com/youxilua/p/2690528.html
Copyright © 2011-2022 走看看