gpt4 book ai didi

java - 使用资源引用属性序列化类实例是否安全?

转载 作者:搜寻专家 更新时间:2023-11-01 08:37:49 27 4
gpt4 key购买 nike

我想序列化一个像这样的对象:

   class Dog implements Serializable{

public String name;
public int iconDrawable;
}

iconDrawable 是一个指向来自 R.java 的drawable 资源 的 int。

所以我可以像这样制作一只狗:

Dog dog = new Dog();
dog.name= "Barky";
dog.iconDrawable = R.drawable.dog_icon; //portrait of a dog instance

我的问题是:

序列化此对象安全吗? iconDrawable 是最终数字吗?我反序列化时是否总是得到相同的可绘制对象? 或者引用可以在应用启动或应用终止时发生变化?

或者我应该将可绘制对象的名称存储在字符串属性字段中并使用 getIdentifier? (有点复杂,但肯定有效)

最佳答案

R.java 是在构建时为您生成的。如果您修改(添加、删除等)资源,或者如果使用新版本的 Android 构建工具来构建项目,它将发生变化。

也就是说,如果您只是在运行时使用它来将对象传输到另一个 Activity/fragment 或类似的东西,那么序列化/反序列化资源 ID 是安全的。

但是,如果您将其序列化以实现持久性,那将不安全,因为这些 ID 可能会在应用程序构建之间发生变化。在这种情况下,最好使用 getIdentifier

关于java - 使用资源引用属性序列化类实例是否安全?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35272941/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com