斯卡拉:有没有办法覆盖“不等于”(!=)?

前端之家收集整理的这篇文章主要介绍了斯卡拉:有没有办法覆盖“不等于”(!=)?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在编写一个生成sql的DSL.加载表的语法是:

session.activateWhere( _.User.ID == 490 )

这将从用户表中选择ID列为490.我可以使用“==”因为我可以覆盖“equals()”来生成正确的sql.我的问题是“!=”不起作用,因为它调用equals()然后否定结果.可悲的是,“!=”是最终的,所以我无法覆盖它.在我的equals()方法中有什么方法可以告诉它是作为!=的一部分调用的吗?

我已经实现了“<>”从逻辑上做与“!=”相同的操作,它运行正常:

session.activateWhere( _.User.ID <> 490 )

我的问题是,不仅“!=”有效语法(对编译器而言),它将运行并生成用户意图完全相反的语法.

解决方法

如你所说,!=是(类似于==)final,所以不能被覆盖 – 这是有充分理由的.这就是大多数DLS使用===作为替代方案的原因.

==和!=运算符可以很好地定义Scala中所有对象的含义.在我看来,改变某些物体的含义是非常危险的.

猜你在找的Scala相关文章