有人能解释一下LeftFirst布尔标志到底是Abstract Relational Comparison Algorithm什么ECMAScript吗?我知道只有一个运算符<处理所有其他关系运算符,如>, >=,正如 ECMAScript 规范中 使用布尔标志的抽象关系比较<=中提到的那样,例如:当我们编写和运行像become和左操作数这样的操作时移动到操作数所在的右边,右边的操作数移动到之前操作数所在的左边,操作符变成操作符,最后执行这样的操作LeftFirst10 > 5LeftFirst Boolean Flagfalse105510><5 < 10,但现在我的问题是:执行时5 < 10我必须知道首先评估什么操作数,是操作数5还是操作数10?我问这个是因为他们在Abstract Relational Comparison AlgorithmECMAScript的规范中没有提到这一点。而且我必须知道为什么>=用LeftFirsttrue 执行以及为什么<=用LeftFirstfalse 执行。请帮助我
1 回答
PIPIONE
TA贡献1829条经验 获得超9个赞
在这些步骤开始之前,预计输入值x
和y
算法描述中的值将被完全评估。该标志是这样的操作ToPrimitive()
以正确的顺序发生。
例如,x
并且y
可能是对象引用。该ToPrimitive()
操作将调用.toString()
或.valueOf()
以执行比较操作。这些函数中的任何一个都可能有副作用,因此该标志确保根据源代码的实际外观以正确的顺序进行操作。
“副作用”是在函数调用中发生的对程序状态的更改。一个toString()
函数可以更改任何其他函数可以更改的任何内容:对象的属性、全局变量等等。该规则确保这些更改以正确的顺序发生(左侧更改在右侧更改之前),无论算法如何“翻转”操作数。
添加回答
举报
0/150
提交
取消