运算符是一个符号,它告诉编译器执行特定的数学或逻辑操作. Scala内置运算符丰富,提供以下类型的运算符 :
算术运算符
关系运算符
逻辑运算符
按位运算符
赋值运算符
本章将逐一检查算术,关系,逻辑,按位,赋值和其他运算符.
Scala语言支持以下算术运算符.例如,让我们假设变量A保持10,变量B保持20,然后 :
运算符 | 描述 | 示例 |
---|---|---|
+ | 添加两个操作数 | A + B将给出30 |
- | 减去第二个操作数从第一个 | A - B将给-10 |
* | 将两个操作数相乘 | A * B将给出200 |
/ | 将分子除以除分子 | B/A将给出2 |
% | 模数运算符在除法后找到余数一个数字的另一个 | B%A将给0 |
Scala语言支持以下关系运算符.例如,让我们假设变量A保持10,变量B保持20,然后 :
运算符 | 描述 | 示例 |
---|---|---|
== | 检查两个操作数的值是否相等,如果是,则条件变为真. | (A == B)不成立. |
!= | 检查两个操作数的值是否相等,如果值是不等于条件变为真. | (A!= B)为真. |
> | 检查左操作数的值是否大于右操作数的值,如果是,那么condi变为真. | (A> B)不是真的. |
< | 检查左操作数的值是否小于右操作数的值,如果是,则条件变为真. | (A< B)为真. |
> = | 检查左操作数的值是否大于或等于到右操作数的值,如果是,则条件变为真. | (A> = B)不成立. |
< = | 检查左操作数的值是否小于或等于右操作数的值,如果是,那么条件变为真. | (A< = B)为真. |
Scala语言支持以下逻辑运算符.例如,假设变量A保持1,变量B保持0,然后是 :
运算符 | 描述 | 示例 |
---|---|---|
&& | 它被称为逻辑AND运算符.如果两个操作数都不为零,则条件变为真. | (A&& B)为假. |
|| | 它被称为逻辑OR运算符.如果两个操作数中的任何一个非零,则条件变为真. | (A || B)为真. |
! | 它被称为逻辑非运算符.用于反转其操作数的逻辑状态.如果条件为真,那么Logical NOT运算符将为false. | !(A&& B)为真. |
按位运算符处理位并执行逐位运算. &,|和^的真值表如下 :
p | q | p& q | p | q | p ^ q |
---|---|---|---|---|
0 | 0 | 0 | 0 | 0 |
0 | 1 | 0 | 1 | 1 |
1 | 1 | 1 | 1 | 0 |
1 | 0 | 0 | 1 | 1 |
假设A = 60;和B = 13;现在是二进制格式,它们将如下 :
A = 0011 1100 B = 0000 1101 - --------------------- A& B = 0000 1100 A | B = 0011 1101 A ^ B = 0011 0001 ~A = 1100 0011
下表列出了Scala语言支持的Bitwise运算符.假设变量A保持60,变量B保持13,然后 :
运算符 | 描述 | 示例 |
---|---|---|
& | Binary AND Operator如果两个操作数中都存在,则将一个位复制到结果中. | (A& B)将给出12,即0000 1100 |
| | 二进制OR运算符如果在任一操作数中都存在,则复制一位. | (A | B)将给出61 ,这是0011 1101 |
^ | 二进制异或运算符如果在一个操作数中设置但不是两者都复制该位. | (A ^ B)将给出49,即0011 0001 |
〜 | 二元一元补码运算符是一元的,具有'翻转'位的效果. | (~A)将给出-61,由于有符号的二进制数,它是2的补码形式的1100 0011. |
<< | 二进制左移运算符.左操作数值的位位置向左移动右操作数指定的位数. | A<< 2将给出240,即1111 0000 |
>> | 二进制右移运算符.左操作数值的位位置向右移动右操作数指定的位数. | A>> 2将给出15,即1111 |
>>> | 右移零填充运算符.左操作数值向右移动右操作数指定的位数,移位值用零填充. | A>>> 2将给出15这是0000 1111 |
有以下Scala语言支持的赋值运算符 :
Operator | 描述 | 示例 |
---|---|---|
= | 简单赋值运算符,从右侧操作数分配值到左侧操作数 | C = A + B将指定A&plus的值; B到C |
+ = | 添加AND赋值运算符,它将右操作数添加到左操作数并将结果赋给左操作数 | C + = A等于C = C + A |
- = | 减去AND赋值运算符,它从左操作数中减去右操作数并将结果赋给左操作数 | C - = A相当于C = C - A |
* = | 乘以AND赋值运算符,它将右操作数与左操作数相乘,并将结果赋值给左操作数 | C * = A相当于C = C * A |
/= | 除以AND赋值运算符,它将左操作数除以右操作数,并将结果赋给左操作数 | C/= A相当于C = C/A |
%= | 模数AND赋值运算符,它使用两个操作数获取模数并将结果赋值给左操作数 | C%= A等于C = C%A |
<< = | 左移和ssignment运算符 | C<< = 2与C = C<< 2 |
>> = | 右移AND赋值运算符 | C>> = 2与C = C>>相同2 |
& = | 按位AND赋值运算符 | C& = 2与C = C& 2 |
^ = | 按位异或或分配运算符 | C ^ = 2与C = C ^ 2相同 |
| = | 按位包含OR和赋值运算符 | C | = 2与C = C |相同2 |
运算符优先级决定了术语的分组在表达中.这会影响表达式的计算方式.某些运营商的优先级高于其他运营商;例如,乘法运算符的优先级高于加法运算符 :
例如,x = 7 + 3 * 2;这里,x被赋值为13,而不是20,因为operator *的优先级高于+,所以它首先乘以3 * 2然后加到7中.
看看下面的内容表.优先级最高的运算符显示在表的顶部,优先级最低的运算符显示在底部.在表达式中,将首先评估更高优先级的运算符.
Category | 运算符 | 关联性 |
---|---|---|
Postfix | ()[] | 从左到右 |
一元 | ! 〜 | 从右到左 |
Multiplicative | */% | 从左到右 |
添加剂 | + - | 从左到右 |
Shift | >> >>> << | 从左到右 |
关系 | > > =< < = | 从左到右 |
Equality | ==!= | 从左到右 |
按位置和 | & | 从左到右 |
按位XOR | ^ | 从左到右 |
按位OR | | | 从左到右 |
逻辑AND | && | 从左到右 |
逻辑或 | || | 从左到右 |
作业 | = + = - = * =/=%=>> ; =<< =& = ^ = | = | 从右到左 |
逗号 | , | 从左到右 |