在 Javascript ES6 中,在浏览器中,我想使用“Transferable”接口将自定义类对象传输到 Web Worker。这可能吗?我可以找到有关 ArrayBuffer 对象的文档,但不能找到自定义类对象。
这不是如何通过 Web-Workers 传递自定义类实例的副本?因为我的问题是关于 Transferable 接口的。我想将我的自定义类实例传递给工作人员而不复制它。
在 Javascript ES6 中,在浏览器中,我想使用“Transferable”接口将自定义类对象传输到 Web Worker。这可能吗?我可以找到有关 ArrayBuffer 对象的文档,但不能找到自定义类对象。
这不是如何通过 Web-Workers 传递自定义类实例的副本?因为我的问题是关于 Transferable 接口的。我想将我的自定义类实例传递给工作人员而不复制它。
我已经以不同的方式多次讨论过这个问题。很抱歉,但您对本次查询的特定版本的答案肯定是否定的。
有几个原因。
ArrayBuffer
实际上只是对现有结构化克隆算法的开销,它可以很好地完成工作。如果你真的想要,我不太确定你应该这样做。
想象这样一个类:
class Vector2 {
constructor(existing) {
this._data = new Float64Array(2);
}
get x() {
return this._data[0];
}
set x(x) {
this._data[0] = x;
}
get y() {
return this._data[1];
}
set y(y) {
this._data[1] = y;
}
}
它的属性存储在数组缓冲区中,您可以传输它。但它还没有多大用处,要让它正常工作,我们需要确保它可以从接收到的数组缓冲区中构造出来。可以肯定地做到这一点:
class Vector2 {
constructor(existing) {
if(existing instanceof ArrayBuffer) {
this.load(existing);
}
else {
this.init();
}
}
/*
* Loads from existing buffer
* @param {ArrayBuffer} existing
*/
load(existing) {
this._data = existing;
this.initProperties();
}
init() {
// 16 bytes, 8 for each Float64
this._data = new ArrayBuffer(16);
this.initProperties();
}
initProperties() {
this._coordsView = new Float64Array(this._data, 0, 2);
}
get x() {
return this._coordsView[0];
}
set x(x) {
this._coordsView[0] = x;
}
get y() {
return this._coordsView[1];
}
set y(y) {
this._coordsView[1] = y;
}
}
现在你甚至可以通过从子类传递更大的数组缓冲区来子类化它,父母和孩子的属性都适合:
class Vector2Altitude extends Vector2 {
constructor(existing) {
super(existing instanceof ArrayBuffer ? existing : new ArrayBuffer(16 + 8));
this._altitudeView = new Float64Array(this._data, 16, 1);
}
get altitude() {
return this._altitudeView[0];
}
set altitude(alt) {
this._altitudeView[0] = alt;
}
}
一个简单的测试:
const test = new Vector2();
console.log(test.x, test.y);
const test2 = new Vector2Altitude();
test2.altitude = 1000;
console.log(test2.x, test2.y, test2.altitude, new Uint8Array(test2._data));
要真正使用它,您需要解决许多其他问题,并从本质上为复杂对象实现自己的内存分配。