gpt4 book ai didi

javascript - 是否有可能在浏览器中发现类型化数组分配限制?

转载 作者:行者123 更新时间:2023-11-30 00:32:01 25 4
gpt4 key购买 nike

试验内存池预分配,我发现分配一个 60M Float32Array 有时会使浏览器选项卡崩溃(在 Chrome 中试过):

var bigArray = new Float32Array(60000000)
for (var i = 0; i < bigArray.length; i+=1) {
bigArray[i] = Math.random()
}

我在一台 8Gb 机器上总共分配了 240MB(即 Float32Array.BYTES_PER_ELEMENT * bigArray.length)。这会使选项卡崩溃 20%,如果我尝试检查 bigArray(例如,尝试在控制台中获取 bigArray.length,记录它,或者更糟糕的是,将鼠标悬停在它上面以查看其内容),则为 100%。

在现代浏览器(主要是 Firefox 和 Chrome)中是否有一种方法(非标准的,随意的)来计算分配限制?我想在限制附近预先分配一个池,并将该池用于我所有后续的 float 数组需求——我并不严格需要分配一个 60M Float32Array,但我想找出我可以尝试分配的最大合理池无需翻动我的标签。

最佳答案

像这样填充一个大缓冲区需要一些时间,并且可能会阻塞浏览器直到 Chrome 说够了。

你需要把它分解成 block ,这样浏览器就可以偶尔喘口气。这将需要一种异步方法。

除此之外:即使浏览器有任意内存限制,即使填充时间很短,它也不应该使选项卡崩溃。如果系统调用内存用完分页,那么这里也不会有太大问题(速度较慢,但​​可用)。如果它仍然与下面的解决方案崩溃,我会说这将是一个错误(然后考虑将其报告给 crbug.com)。

这是一种异步填充大缓冲区的方法:

function getFilledFloat32(size, callback) {
try {
var bigArray = new Float32Array(size), // allocate buffer
blockSize = 2 * 1024*1024, // 2mb blocks
block = blockSize, current = 0; // init block break and position

(function fill() {
while(current < size && block--)
bigArray[current++] = Math.random(); // fill buffer until end or block

if (current < size) { // was block
block = blockSize; // reset block-size
document.querySelector('span').innerHTML += "."; // !! just for demo
setTimeout(fill, 7); // wait 7ms, continue
}
else callback(bigArray) // we're done, invoke callback
})();
} catch(err) {
alert("Error: " + err.message);
}
}

// --- test code ----------------------------

var isBusy = false;
function fill() {
if (isBusy) return;
isBusy = true;
var mb = +document.getElementById("rngMem").value;
document.querySelector('span').innerHTML = "Filling.";
getFilledFloat32(mb * 1024*1024, function(buffer) {
alert("Done! First two indexes:\n" + buffer[0] + ",\n" + buffer[1]);
isBusy = false;
});
}
<label for="mem">Size in MB:</label>
<input id="rngMem" onchange="document.querySelector('output').value = this.value" type="range" min=10 max=500 value=60>
<output>60</output>
<button onclick="fill()">FILL</button>
<br><span></span>

关于javascript - 是否有可能在浏览器中发现类型化数组分配限制?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29111339/

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