我在一个 Activity 上有大约 34 个复选框,我必须标记和取消标记。我想保存每个复选框的状态。
我一直想要这个。那么我应该有一个 sqlite 表或首选项吗?
如果推荐使用 sqlite 表,那么理想的表结构设计应该是怎样的呢?
您可以使用 SQLite 或首选项来完成。虽然...您想做的事情有点简单,那么您为什么要关心创建表格、创建SQliteOpenHelper
对象、设计表格等。首选项方法更简单。
所以......这里最重要的是你如何识别你的复选框。如果您只有 34 个静态复选框(意味着它们不会更改其顺序)并且它们位于一个数组中(这将是理想的),那么您就很容易了。
您可能知道,首选项编辑器不允许保存数组。所以你有一些选择:
putBoolean("checkbox2", true)
; putBoolean("checkbox3", false)
; 等)putString("checkboxes_state", "10101011100011010")
; 这样,您将拥有一个包含 34 个字符的字符串,每个字符代表一个状态。long
等于或小于 17179869183 来表示所有状态。例如putLong("checkboxes_state", 17179869183)
,这意味着所有的复选框都被选中(因为它的二进制表示是 1111111111111111111111111111111111)。更多示例:
关于你为什么最后一个更有效的问题,让我简要解释一下。第一个意味着使用 34 个偏好插槽(实际上我不知道它们是如何存储的;希望 android 团队负责性能)。第二种方法将使用 34 个字符的字符串;因此,String 对象的最小大小为:
minimum String memory usage (bytes) = 8 * (int) ((34 * 2 + 45) / 8) = 113 bytes
这意味着该长度的字符串将占用至少113 个字节。另一方面,仅使用一个 long 将仅占用8 个字节。使用的字节数越少,您的应用程序就会越快(因为 Android 必须处理和保存的字节数越少)。