- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在 JavaScript 中,there is a point “参数泄漏”会影响优化。例如:
function leakingArguments() {
var a = arguments;
return function() {
return a;
};
}
参数泄漏
这是在该函数外部使用的函数参数。在这种情况下,编译器可能不会优化该代码。
所以我建立了一个jsperf ,他们的表现是平等的。看来将参数传递出函数不会影响结果执行时间。
let MAX_LENGTH = 1000
let arr = Array.from({length: MAX_LENGTH}, (v, i) => i)
let withoutArguments = function() {
let cloneArgs = Array.apply(null, arguments)
return function() {
cloneArgs[0] = 1
return
}
}
let argumentsFn = function() {
let args = arguments
let cloneArgs = Array.apply(null, arguments)
return function() {
args[0] = 1
return
}
}
withoutArguments(...arr)
argumentsFn(...arr)
真的存在“参数泄露”吗?
最佳答案
我想质疑您的性能测试用例,因为:
(1) 您只调用这些函数一次,引擎 JIT 不太可能编译它们,而这正是优化真正重要的地方。
(2) 您从未调用返回的函数,因此您从未真正修改参数
。
(3) arguments
的主要问题是值必须实时反射(reflect)到闭包变量中,因此这个测试用例会更好:
function urgh(a) {
const leak = arguments;
return function() {
leak.a = 1;
console.log(a);
};
}
关于javascript - “leaking arguments”是谎言吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57504744/
我发现人们声称在一个类中使用所有只读字段并不一定会使该类的实例不可变,因为即使在初始化(构造)之后也有更改只读字段值的“方法”。 如何?有什么方法? 所以我的问题是什么时候我们才能在 C# 中真正拥有
所以我创建了一个幻灯片。幻灯片使用两个重叠的媒体元素来显示图片。过渡只是意味着减少前景元素的不透明度并增加背景元素的不透明度。 问题是图片加载到媒体元素的速度不够快。这会导致口吃并且通常看起来很糟糕。
我在 linux 集群上运行了一些 python 脚本,一个作业的输出通常是另一个脚本的输入,可能在另一个节点上运行。我发现在 python 注意到已在其他节点上创建的文件之前存在一些并非微不足道的延
看来我不是唯一发现这一点的人: http://forums.devx.com/showthread.php?t=72771 实际上两者都是: InternetGetConnectedState Int
我是一名优秀的程序员,十分优秀!