Java-Operatoren können in 4 Kategorien unterteilt werden: arithmetische Operatoren, relationale Operatoren, logische Operatoren und bitweise Operatoren.
Arithmetische Operatoren
Die arithmetischen Operatoren von Java sind in unäre Operatoren und binäre Operatoren unterteilt. Unäre Operatoren haben nur einen Operanden; binäre Operatoren haben zwei Operanden, und der Operator befindet sich zwischen den beiden Operanden. Die Operanden arithmetischer Operatoren müssen vom numerischen Typ sein.
1. Unäre Operatoren:
Zu den unären Operatoren gehören: positiv (+), negativ (-), plus 1 (++) und minus 1 (- - ) 4.
Operatoren zum Addieren von 1 und Subtrahieren von 1 dürfen nur für Variablen vom numerischen Typ verwendet werden und dürfen nicht in Ausdrücken verwendet werden. Die Plus-1- und Minus-1-Operatoren können vor der Variablen (z. B. ++i) oder nach der Variablen (z. B. i++) platziert werden. Der Unterschied zwischen den beiden ist: Wenn sie vor der Variablen platziert werden (z. B. ++i), Der Variablenwert wird zuerst um 1 oder minus 1 addiert und dann werden andere entsprechende Operationen ausgeführt (hauptsächlich Zuweisungsoperationen). Wenn er nach der Variablen platziert wird (z. B. i++), werden zuerst andere entsprechende Operationen ausgeführt und dann 1 zum Variablenwert addiert oder subtrahiert .
Zum Beispiel:
int i=6,j,k,m,n; j = +i;//取原值,即j=6 k = -i;//取负值,即k=-6 m = i++;//先m=i,再i=i+1,即m=6,i=7 m = ++i;//先i=i+1,再m=i,即i=7,m=7 n = j--;//先n=j,再j=j-1,即n=6,j=5 n = --j;//先j=j-1,再n=j,即j=5,n=5
Beachten Sie beim Schreiben außerdem: Zwischen unären Operatoren und ihren vorhergehenden und nachfolgenden Operanden sind keine Leerzeichen zulässig, da es sonst beim Kompilieren zu einem Fehler kommt.
2. Binäre Operatoren
Zu den binären Operatoren gehören: Addition (+), Subtraktion (-), Multiplikation (*), Division (/), Rest bilden ( %). Darunter vervollständigen +, -, *, / die vier arithmetischen Operationen Addition, Subtraktion, Multiplikation und Division, und % dient dazu, den Rest nach der Division der beiden Operanden zu ermitteln.
Beispiel für eine %-Restoperation:
a % b = a - (a / b) * b
Der Restoperator kann nicht nur verwendet werden, wenn beide Operanden Ganzzahlen sind, sondern auch, wenn beide Operanden Gleitkommazahlen sind (oder ein Operand eine Gleitkommazahl ist). ). Wenn beide Operanden Gleitkommazahlen sind, beispielsweise 7,6 % 2,9, lautet das Berechnungsergebnis: 7,6 - 2 * 2,9 = 1,8.
Wenn beide Operanden vom Typ int sind, lautet die Berechnungsformel von a%b:
a % b = a - (int)(a / b) * b
Wenn beide Operanden vom Typ long (oder anderen Ganzzahltypen) sind, lautet die Berechnungsformel von a% b kann durch Analogie abgeleitet werden.
Wenn die Datentypen der beiden an einer Binäroperation beteiligten Operanden unterschiedlich sind, stimmt der Datentyp des Ergebnisses mit dem Datentyp mit höherer Genauigkeit (oder längeren Ziffern) überein.
Zum Beispiel:
7 / 3 //Ganzzahldivision, das Operationsergebnis ist 2
7,0 / 3 //Division, das Operationsergebnis ist 2,33333, Das heißt, das Ergebnis und die Genauigkeit Der höhere Typ ist konsistent
7 % 3 //Rest, das Operationsergebnis ist 1
7,0 % 3 //Rest, das Operationsergebnis ist 1,0
-7 % 3 //Rest, das Operationsergebnis ist -1, das heißt, das Vorzeichen des Operationsergebnisses ist das gleiche wie das des linken Operanden
7 % -3 //Rest, der Das Operationsergebnis ist 1, das heißt, das Vorzeichen des Operationsergebnisses ist das gleiche wie das des linken Operanden. Die Zahlen sind gleich
Relationaloperator
Der Vergleichsoperator wird verwendet, um die Größe zweier Werte zu vergleichen. Das Ergebnis der Operation ist ein numerischer Wert vom logischen Typ. Es gibt sechs Vergleichsoperatoren: gleich (==), ungleich (!=), größer als (>), größer oder gleich (>=), kleiner als (4ac2f1ea787a29d9d63bbca6bedd2549= 8,8 //Das Operationsergebnis ist wahr
'A' f08b5de8c512177c0cf86f851959d198= 9 ist das Operationsergebnis von 9 >= 9 wahr, da 9 gleich 9 ist.
Logische Operatoren
Logische Operatoren erfordern, dass der Datentyp des Operanden ein logischer Typ ist und sein Operationsergebnis ebenfalls ein logischer Typwert ist . Zu den logischen Operatoren gehören: logisches UND (&&), logisches ODER (||), logisches NICHT (!), logisches XOR (^), logisches UND (&) und logisches ODER (|).
Die Wahrheitstabelle ist eine intuitive Möglichkeit, die Funktion logischer Operationen auszudrücken. Die spezifische Methode besteht darin, alle möglichen Werte logischer Operationen in tabellarischer Form aufzulisten. Die Wahrheitstabelle logischer Operatoren in der Java-Sprache lautet wie folgt:
Die Wahrheitstabelle logischer Operatoren
A B A&&B A||B !A A^BA&BA|B
falsch falsch falsch falsch wahr falsch falsch falsch
wahr falsch falsch wahr falsch wahr falsch wahr
falsch wahr falsch wahr wahr wahr falsch wahr
wahr wahr falsch wahr wahr falsch falsch wahr wahr
前两列是参与逻辑运算的两个逻辑变量,共有4种可能,所以表2.5共有4行。后6列分别是6个逻辑运算符在逻辑变量A和逻辑变量B取不同数值时的运算结果值。
要说明的是,两种逻辑与(&&和&)的运算规则基本相同,两种逻辑或(||和|)的运算规则也基本相同。其区别是:&和|运算是把逻辑表达式全部计算完,而&&和||运算具有短路计算功能。所谓短路计算,是指系统从左至右进行逻辑表达式的计算,一旦出现计算结果已经确定的情况,则计算过程即被终止。对于&&运算来说,只要运算符左端的值为false,则因无论运算符右端的值为true或为false,其最终结果都为false。所以,系统一旦判断出&&运算符左端的值为false,则系统将终止其后的计算过程;对于 || 运算来说,只要运算符左端的值为true,则因无论运算符右端的值为true或为false,其最终结果都为true。所以,系统一旦判断出|| 运算符左端的值为true,则系统将终止其后的计算过程。
例如,有如下逻辑表达式:
(i>=1) && (i<=100)
此时,若i等于0,则系统判断出i>=1的计算结果为false后,系统马上得出该逻辑表达式的最终计算结果为false,因此,系统不继续判断ic387271006a58240a751d62eb30f84b3>)、左移(0e0c73725f0461daa2f74889ad0d988d>>)。
位运算的位与(&)、位或(|)、位非(~)、位异或(^)与逻辑运算的相应操作的真值表完全相同,其差别只是位运算操作的操作数和运算结果都是二进制整数,而逻辑运算相应操作的操作数和运算结果都是逻辑值。
位运算示例
运算符 名称 示例说明
& 位与x&y 把x和y按位求与
| 位或x|y 把x和y按位求或
~ 位非~x 把x按位求非
^ 位异或 x^y 把x和y按位求异或
>> 右移x>>y把x的各位右移y位
a3b498cebd6c2c5721c9ea9fbfbb606e>> 右移x>>>y 把x的各位右移y位,左边填0
举例说明:
1、有如下程序段:
int x = 64; //x等于二进制数的01000000 int y = 70; //y等于二进制数的01000110 int z = x&y //z等于二进制数的01000000
即运算结果为z等于二进制数01000000。位或、位非、位异或的运算方法类同。
2、右移是将一个二进制数按指定移动的位数向右移位,移掉的被丢弃,左边移进的部分或者补0(当该数为正时),或者补1(当该数为负时)。这是因为整数在机器内部采用补码表示法,正数的符号位为0,负数的符号位为1。例如,对于如下程序段:
int x = 70; //x等于二进制数的01000110 int y = 2; int z = x>>y //z等于二进制数的00010001
即运算结果为z等于二进制数00010001,即z等于十进制数17。
对于如下程序段:
int x = -70; //x等于二进制数的11000110 int y = 2; int z = x>>y //z等于二进制数的11101110
即运算结果为z等于二进制数11101110,即z等于十进制数-18。要透彻理解右移和左移操作,读者需要掌握整数机器数的补码表示法。
3、0填充的右移(>>>)是不论被移动数是正数还是负数,左边移进的部分一律补0。
其他运算符
1、赋值运算符与其他运算符的简捷使用方式
赋值运算符可以与二元算术运算符、逻辑运算符和位运算符组合成简捷运算符,从而可以简化一些常用表达式的书写。
赋值运算符与其他运算符的简捷使用方式
运算符 用法 等价于说明
+= s+=is=s+i s,i是数值型
-= s-=is=s-i s,i是数值型
*= s*=is=s*i s,i是数值型
/= s/=is=s/i s,i是数值型
%= s%=is=s%i s,i是数值型
&= a&=ba=a&b a,b是逻辑型或整型
|= a|=ba=a|b a,b是逻辑型或整型
^= A^=ba=a^b a,b是逻辑型或整型
ba26955435af236af04aa58272198ee2>=s>>=i s=s>>is,i是整型
>>>= s>>>=i s=s>>>i s,i是整型
2、方括号[]和圆括号()运算符
方括号[]是数组运算符,方括号[]中的数值是数组的下标,整个表达式就代表数组中该下标所在位置的元素值。
圆括号()运算符用于改变表达式中运算符的优先级。
3、字符串加(+)运算符
当操作数是字符串时,加(+)运算符用来合并两个字符串;当加(+)运算符的一边是字符串,另一边是数值时,机器将自动将数值转换为字符串,这种情况在输出语句中很常见。如对于如下程序段:
int max = 100; System.out.println("max = "+max);
计算机屏幕的输出结果为:max = 100,即此时是把变量max中的整数值100转换成字符串100输出的。
4、条件运算符(?:)
条件运算符(?:)的语法形式为:
<表达式1> ?<表达式2> : <表达式3>
条件运算符的运算方法是:先计算27323b5ed8b44e0a297ecdb3b75fdcb7的值,当27323b5ed8b44e0a297ecdb3b75fdcb7的值为true时,则将47412bb27b333d7ef9616246112cd095的值作为整个表达式的值;当27323b5ed8b44e0a297ecdb3b75fdcb7的值为false时,则将724757b3a0af45ea06676406dc49b26a的值作为整个表达式的值。如:
int a=1,b=2,max; max = a>b?a:b; //max等于2
5、强制类型转换符
强制类型转换符能将一个表达式的类型强制转换为某一指定数据类型,其语法形式为:
(<类型>)<表达式>
6、对象运算符instanceof
对象运算符instanceof用来测试一个指定对象是否是指定类(或它的子类)的实例,若是则返回true,否则返回false。
7、点运算符
点运算符“.”的功能有两个:一是引用类中成员,二是指示包的层次等级。
运算符的优先级
以下按优先级从高到低的次序列出Java语言中的所有运算符,表中结合性一列中的“左右”表示其运算次序为从左向右,“右左”表示其运算次序为从右向左。
优先级 运算符 结合性
1 . [] () ; ,
2 ++ ―― += ! ~ +(一元) -(一元) 右左
3 * / % 左右
4 +(二元) -(二元) 左右
5 9bfa42134ac435362733abbb2296c9ff> >>> 左右
6 377520d3212f646022f09a9470e4b397 c8641a367e3336f63c920347c30ba2c5= instanceof 左右
7 = = != 左右
8 &左右
9 ^左右
10 |左右
11 && 左右
12 || 左右
13 ?: 右左
14 = *= /= %= += -=
= >>>= &= ^= |= 右左
推荐学习:Java视频教程
Das obige ist der detaillierte Inhalt vonWas sind die Operatoren in Java?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!