如何解决如何防止单例对象被克隆?
我通过以下方式实现了单例模式:
class Singleton {
static #instance_holder = [];
constructor() {
if (0 !== Singleton.#instance_holder.length) return Singleton.#instance_holder[0];
Singleton.#instance_holder.push(this);
Object.preventExtensions(this);
console.log("You'll see me only once,when the object is first instantiated.");
}
}
就常规声明/赋值而言,这似乎工作正常:
const s1 = new Singleton();
//OUTPUT: You'll see me only once,when the object is first instantiated.
const s2 = new Singleton(); //no additional instantiation,the existing one is assigned to s2
s1 instanceof Singleton //true
s2 instanceof Singleton //true
s1 === s2 //true
但是,仍然可以使用 s1
或 Object.create
或 Object.assign
克隆实例 (JSON.parse(JSON.stringify(s1))
)。
const clone = Object.create(s1);
clone instanceof Singleton //true
clone === s1 //false
如何防止对象以这些方式被克隆?
解决方法
基本上,你不能。没有阻止克隆的 JS 机制。
如果某些东西成为单例非常重要,那么它可能是您真正关心的那个类中的某些东西。在这种情况下,最好将它放在全局范围内并让您的类引用它。
const data = {};
class Singleton {
// singleton setup
doSomething() {
return data.something();
}
}
这将确保即使单例被克隆,只要它使用相同的数据源,它仍然像单例一样工作。
也就是说……我真的不建议这样做。我真的想不出您实际上需要强制执行真正的单身人士的情况。如果有人用他们的代码做了一些愚蠢的事情,那就是他们的问题。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。