为了账号安全,请及时绑定邮箱和手机立即绑定

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

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

智慧大石 2022-05-26 16:40:21
有人能解释一下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个赞

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

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

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


查看完整回答
反对 回复 2022-05-26
  • 1 回答
  • 0 关注
  • 137 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信