Scala的關(guān)系和邏輯操作方法是什么

本篇內(nèi)容介紹了“Scala的關(guān)系和邏輯操作方法是什么”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!

創(chuàng)新互聯(lián)主營丹棱網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,成都App定制開發(fā),丹棱h5小程序開發(fā)搭建,丹棱網(wǎng)站營銷推廣歡迎丹棱等地區(qū)企業(yè)咨詢

數(shù)學(xué)運算

你可以通過中綴操作符,加號(+),減號(-),乘號(*),除號(/)和余數(shù)(%),在任何數(shù)類型上調(diào)用數(shù)學(xué)方法。以下是一些例子:

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

當(dāng)左右兩個操作數(shù)都是整數(shù)類型時(Int,Long,Byte,Short,或Char),/操作符將返回給你商的整數(shù)部分,去掉余數(shù)部分。%操作符指明它的余數(shù)。

用%符號得到的浮點數(shù)余數(shù)部分并不遵循IEEE754標(biāo)準(zhǔn)的定義。IEEE754在計算余數(shù)時使用四舍五入除法,而不是截尾除法,因此余數(shù)的計算與整數(shù)的余數(shù)操作會有很大的不同。如果你的確想要IEEE754的余數(shù),可以調(diào)用scala.Math里的IEEEremainder,例如:

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

數(shù)類型還提供了一元前綴+和-操作符(方法unary_+和unary_-),允許你指示文本數(shù)是正的還是負的,如-3或+4.0。如果你沒有指定一元的+或-,文本數(shù)被解釋為正的。一元符號+也存在只是為了與一元符號-相協(xié)調(diào),不過沒有任何效果。一元符號-還可以用來使變量變成負值。舉例如下:

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

關(guān)系和邏輯操作

你可以用關(guān)系方法:大于(>),小于(< ),大于等于(>=)和小于等于(< =)比較數(shù)類型,像等號操作符那樣,產(chǎn)生一個Boolean結(jié)果。另外,你可以使用一元操作符!(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操作數(shù)并產(chǎn)生Boolean結(jié)果。如:

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的概念:用這些操作符建造的表達式僅評估最少能決定結(jié)果的部分。換句話說,邏輯與和邏輯或表達式的右手側(cè)部分在左手側(cè)部分能決定結(jié)果時就不再被評估了。舉個例子,如果邏輯與表達式的左手側(cè)計算結(jié)果為false,那么表達式的結(jié)果將注定是false,因此右手側(cè)部分不再做評估。與之類似,如果邏輯或表達式的左手側(cè)部分計算結(jié)果為true,那么表達式的結(jié)果將必然是true,于是右手側(cè)部分不再被計算。下面是一些例子:

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都被調(diào)用,但第二個里,只有salt被調(diào)用。因為salt返回false,所以就沒必要調(diào)用pepper了。

注意

或許你會想知道如果操作符都只是方法的話短路機制是怎么工作的呢。通常,進入方法之前所有的參數(shù)都會被評估,因此方法怎么可能選擇不評估他的第二個參數(shù)呢?答案是因為所有的Scala方法都有延遲其參數(shù)評估乃至取消評估的設(shè)置。

位操作符

Scala讓你能夠使用若干位方法對整數(shù)類型的單個位執(zhí)行操作。有:按位與運算(&),按位或運算(|)和按位異或運算(^)。按位異或方法對它的操作數(shù)執(zhí)行互斥或:exclusive or操作。一致的位產(chǎn)生0。差異的位產(chǎn)生1。因此0011 ^ 0101產(chǎn)生0110。一元按位取補操作符(~,方法unary_~),反轉(zhuǎn)它的操作數(shù)的每一位。例如:

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)的每一個位,并產(chǎn)生了0(0000)。第二個表達式,1 | 2,對同樣的操作數(shù)的每一個位執(zhí)行或運算,并產(chǎn)生3(0011)。第三個表達式,1 ^ 3,異或1(0001)和3(0011)的每一個位,產(chǎn)生2(0010)。***的表達式,~1,轉(zhuǎn)換了1(0001)的每一個位,產(chǎn)生了-2,二進制看起來是1111 1111 1111 1111 1111 1111 1111 1111 1111 1110。

Scala整數(shù)類型還提供了三個位移方法:左移(< < ),右移(>>)和無符號右移(>>>)。使用在中綴操作符方式時,位移方法會按照右側(cè)指定的整數(shù)值次數(shù)逐位移動左側(cè)的整數(shù)。左移和無符號右移在移動的時候填入零。右移則在移動時填入左側(cè)整數(shù)的***位(符號位)。舉例如下:

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位,這個操作實際就是把最左側(cè)的一位移到了最右側(cè)。數(shù)字類型的最左側(cè)位是符號位。如果最左側(cè)位是1,數(shù)字就是負的,如果是0,數(shù)字就是正的。由于>>方法在不斷右移的時候填入的是1,-1最左側(cè)的一位是1,導(dǎo)致結(jié)果與原來左側(cè)的數(shù)字一模一樣,32位個1,或者說是-1。第二個例子里,-1 >>> 31,最左側(cè)的位再一次不斷向右移直至最右側(cè)的位置,但是這次填入的是0。因此這次的結(jié)果是二進制的0000 0000 0000 0000 0000 0000 0000 0001,或者說是1。***一個例子里,1 < <  2,左操作數(shù),1,被向左移動2個位置(填入0),產(chǎn)生結(jié)果是二進制的0000 0000 0000 0000 0000 0000 0000 0100,或者說是4。

“Scala的關(guān)系和邏輯操作方法是什么”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!

標(biāo)題名稱:Scala的關(guān)系和邏輯操作方法是什么
文章URL:http://muchs.cn/article48/gpgghp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供建站公司、靜態(tài)網(wǎng)站面包屑導(dǎo)航、搜索引擎優(yōu)化企業(yè)建站、網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

小程序開發(fā)