1

有人能解释一下LeftFirst布尔标志到底是Abstract Relational Comparison Algorithm什么ECMAScript吗?我知道只有一个运算符<处理所有其他关系运算符,如>, >=,正如 ECMAScript 规范中 使用布尔标志的抽象关系比较<=中提到的那样,例如:当我们编写和运行像become和左操作数这样的操作时移动到操作数所在的右边,右边的操作数移动到之前操作数所在的左边,操作符变成操作符,最后执行这样的操作LeftFirst10 > 5LeftFirst Boolean Flagfalse105510><5 < 10,但现在我的问题是:执行时5 < 10我必须知道首先评估什么操作数,是操作数5还是操作数10?我问这个是因为他们在Abstract Relational Comparison AlgorithmECMAScript的规范中没有提到这一点。

而且我必须知道为什么>=LeftFirsttrue 执行以及为什么<=LeftFirstfalse 执行。请帮助我

4

1 回答 1

1

在这些步骤开始之前,预计输入值xy算法描述中的值将被完全评估。该标志是这样的操作ToPrimitive()以正确的顺序发生。

例如,x并且y可能是对象引用。该ToPrimitive()操作将调用.toString().valueOf()以执行比较操作。这些函数中的任何一个都可能有副作用,因此该标志确保根据源代码的实际外观以正确的顺序进行操作。

“副作用”是在函数调用中发生的对程序状态的更改。一个toString()函数可以更改任何其他函数可以更改的任何内容:对象的属性、全局变量等等。该规则确保这些更改以正确的顺序发生(左侧更改在右侧更改之前),无论算法如何“翻转”操作数。

于 2020-03-22T13:35:49.973 回答