猿问

ECMAScript 的“抽象关系比较算法”中的“LeftFirst”布尔标志到底是什么?

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

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


智慧大石
浏览 138回答 1
1回答

PIPIONE

在这些步骤开始之前,预计输入值x和y算法描述中的值将被完全评估。该标志是这样的操作ToPrimitive()以正确的顺序发生。例如,x并且y可能是对象引用。该ToPrimitive()操作将调用.toString()或.valueOf()以执行比较操作。这些函数中的任何一个都可能有副作用,因此该标志确保根据源代码的实际外观以正确的顺序进行操作。“副作用”是在函数调用中发生的对程序状态的更改。一个toString()函数可以更改任何其他函数可以更改的任何内容:对象的属性、全局变量等等。该规则确保这些更改以正确的顺序发生(左侧更改在右侧更改之前),无论算法如何“翻转”操作数。
随时随地看视频慕课网APP

相关分类

JavaScript
我要回答