温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Scala的关系和逻辑操作方法是什么

发布时间:2021-12-10 10:31:53 来源:亿速云 阅读:168 作者:iii 栏目:编程语言

本篇内容介绍了“Scala的关系和逻辑操作方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

数学运算

你可以通过中缀操作符,加号(+),减号(-),乘号(*),除号(/)和余数(%),在任何数类型上调用数学方法。以下是一些例子:

scala> 1.2 + 2.3 res6: Double = 3.5 scala> 3 - 1 res7: Int = 2 scala> 'b' - 'a' res8: Int = 1 scala> 2L * 3L  res9: Long = 6 scala> 11 / 4 res10: Int = 2 scala> 11 % 4 res11: Int = 3 scala> 11.0f / 4.0f  res12: Float = 2.75 scala> 11.0 % 4.0 res13: Double = 3.0

当左右两个操作数都是整数类型时(Int,Long,Byte,Short,或Char),/操作符将返回给你商的整数部分,去掉余数部分。%操作符指明它的余数。

用%符号得到的浮点数余数部分并不遵循IEEE754标准的定义。IEEE754在计算余数时使用四舍五入除法,而不是截尾除法,因此余数的计算与整数的余数操作会有很大的不同。如果你的确想要IEEE754的余数,可以调用scala.Math里的IEEEremainder,例如:

scala> Math.IEEEremainder(11.0, 4.0)  res14: Double = -1.0

数类型还提供了一元前缀+和-操作符(方法unary_+和unary_-),允许你指示文本数是正的还是负的,如-3或+4.0。如果你没有指定一元的+或-,文本数被解释为正的。一元符号+也存在只是为了与一元符号-相协调,不过没有任何效果。一元符号-还可以用来使变量变成负值。举例如下:

scala> val neg = 1 + -3 neg: Int = -2 scala> val y = +3 y: Int = 3 scala> -neg  res15: Int = 2

关系和逻辑操作

你可以用关系方法:大于(>),小于(< ),大于等于(>=)和小于等于(< =)比较数类型,像等号操作符那样,产生一个Boolean结果。另外,你可以使用一元操作符!(unary_!方法)改变Boolean值。以下是一些例子:

scala> 1 > 2 res16: Boolean = false scala> 1 <  2 res17: Boolean = true scala> 1.0 < = 1.0 res18: Boolean = true scala> 3.5f >= 3.6f  res19: Boolean = false scala> 'a' >= 'A' res20: Boolean = true scala> val thisIsBoring = !true thisIsBoring: Boolean = false scala> !thisIsBoring  res21: Boolean = true

逻辑方法,逻辑与(&&)和逻辑或(||),以中缀方式带Boolean操作数并产生Boolean结果。如:

scala> val toBe = true toBe: Boolean = true scala> val question = toBe || !toBe  question: Boolean = true scala> val paradox = toBe && !toBe  paradox: Boolean = false

与Java里一样,逻辑与和逻辑或有短路:short-circuit的概念:用这些操作符建造的表达式仅评估最少能决定结果的部分。换句话说,逻辑与和逻辑或表达式的右手侧部分在左手侧部分能决定结果时就不再被评估了。举个例子,如果逻辑与表达式的左手侧计算结果为false,那么表达式的结果将注定是false,因此右手侧部分不再做评估。与之类似,如果逻辑或表达式的左手侧部分计算结果为true,那么表达式的结果将必然是true,于是右手侧部分不再被计算。下面是一些例子:

scala> def salt() = { println("salt"); false }  salt: ()Boolean  scala> def pepper() = { println("pepper"); true }  pepper: ()Boolean  scala> pepper() && salt()  pepper  salt  res22: Boolean = false scala> salt() && pepper()  salt  res23: Boolean = false

***个表达式中,pepper和salt都被调用,但第二个里,只有salt被调用。因为salt返回false,所以就没必要调用pepper了。

注意

或许你会想知道如果操作符都只是方法的话短路机制是怎么工作的呢。通常,进入方法之前所有的参数都会被评估,因此方法怎么可能选择不评估他的第二个参数呢?答案是因为所有的Scala方法都有延迟其参数评估乃至取消评估的设置。

位操作符

Scala让你能够使用若干位方法对整数类型的单个位执行操作。有:按位与运算(&),按位或运算(|)和按位异或运算(^)。按位异或方法对它的操作数执行互斥或:exclusive or操作。一致的位产生0。差异的位产生1。因此0011 ^ 0101产生0110。一元按位取补操作符(~,方法unary_~),反转它的操作数的每一位。例如:

scala> 1 & 2 res24: Int = 0 scala> 1 | 2 res25: Int = 3 scala> 1 ˆ 3 res26: Int = 2 scala> ~1 res27: Int = -2

***个表达式,1 & 2,与运算了1(0001)和2(0010)的每一个位,并产生了0(0000)。第二个表达式,1 | 2,对同样的操作数的每一个位执行或运算,并产生3(0011)。第三个表达式,1 ^ 3,异或1(0001)和3(0011)的每一个位,产生2(0010)。***的表达式,~1,转换了1(0001)的每一个位,产生了-2,二进制看起来是1111 1111 1111 1111 1111 1111 1111 1111 1111 1110。

Scala整数类型还提供了三个位移方法:左移(< < ),右移(>>)和无符号右移(>>>)。使用在中缀操作符方式时,位移方法会按照右侧指定的整数值次数逐位移动左侧的整数。左移和无符号右移在移动的时候填入零。右移则在移动时填入左侧整数的***位(符号位)。举例如下:

scala> -1 >> 31 res38: Int = -1 scala> -1 >>> 31 res39: Int = 1 scala> 1 < <  2 res40: Int = 4

二进制的-1是1111 1111 1111 1111 1111 1111 1111 1111。***个例子里,-1 >> 31,-1被右移了31个位。由于Int包括32位,这个操作实际就是把最左侧的一位移到了最右侧。数字类型的最左侧位是符号位。如果最左侧位是1,数字就是负的,如果是0,数字就是正的。由于>>方法在不断右移的时候填入的是1,-1最左侧的一位是1,导致结果与原来左侧的数字一模一样,32位个1,或者说是-1。第二个例子里,-1 >>> 31,最左侧的位再一次不断向右移直至最右侧的位置,但是这次填入的是0。因此这次的结果是二进制的0000 0000 0000 0000 0000 0000 0000 0001,或者说是1。***一个例子里,1 < <  2,左操作数,1,被向左移动2个位置(填入0),产生结果是二进制的0000 0000 0000 0000 0000 0000 0000 0100,或者说是4。

“Scala的关系和逻辑操作方法是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI