喝醉的电脑桌 · 博物馆开发文创产品成“网红” ...· 6 月前 · |
坏坏的斑马 · 商用车新能源首届创富+高峰论坛暨开瑞小象EV ...· 1 年前 · |
帅气的甘蔗 · 销量下滑只是雷克萨斯在华溃败的开始?· 1 年前 · |
大鼻子的消防车 · 12 神秘灵戒,在线教学-炼废通神-漫画牛· 1 年前 · |
气势凌人的可乐 · 电动屋YOUNG光小新,纯电续航40_懂车帝· 1 年前 · |
以上实例编译运行结果如下:
a + b = 30 a - b = -10 a * b = 200 b / a = 2 b % a = 0 c % a = 5 a++ = 10 a-- = 11 d++ = 25 ++d = 271、自增(++)自减(--)运算符 是一种特殊的算术运算符,在算术运算符中需要两个操作数来进行运算,而自增自减运算符是一个操作数。
运行结果为:
进行自增运算后的值等于4 进行自减运算后的值等于2int b = ++a; 拆分运算过程为: a=a+1=4; b=a=4, 最后结果为b=4,a=4
int d = --c; 拆分运算过程为: c=c-1=2; d=c=2, 最后结果为d=2,c=2
2、前缀自增自减法(++a,--a): 先进行自增或者自减运算,再进行表达式运算。
3、后缀自增自减法(a++,a--): 先进行表达式运算,再进行自增或者自减运算
运行结果为:
自增运算符前缀运算后a=6,x=12 自增运算符后缀运算后b=6,y=10下表为Java支持的关系运算符
表格中的实例整数变量A的值为10,变量B的值为20:
int b = 20 ; System . out . println ( " a == b = " + ( a == b ) ) ; System . out . println ( " a != b = " + ( a != b ) ) ; System . out . println ( " a > b = " + ( a > b ) ) ; System . out . println ( " a < b = " + ( a < b ) ) ; System . out . println ( " b >= a = " + ( b >= a ) ) ; System . out . println ( " b <= a = " + ( b <= a ) ) ;以上实例编译运行结果如下:
a == b = false a != b = true a > b = false a < b = true b >= a = true b <= a = false Java定义了位运算符,应用于整数类型(int),长整型(long),短整型(short),字符型(char),和字节型(byte)等类型。 位运算符作用在所有的位上,并且按位运算。假设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
下表列出了位运算符的基本运算,假设整数变量 A 的值为 60 和变量 B 的值为 13:
以上实例编译运行结果如下:
a & b = 12 a | b = 61 a ^ b = 49 ~a = -61 a << 2 = 240 a >> 2 = 15 a >>> 2 = 15下表列出了逻辑运算符的基本运算,假设布尔变量A为真,变量B为假
以上实例编译运行结果如下:
a && b = false a || b = true !(a && b) = true当使用与逻辑运算符时,在两个操作数都为true时,结果才为true,但是当得到第一个操作为false时,其结果就必定是false,这时候就不会再判断第二个操作了。
运行结果为:
使用短路逻辑运算符的结果为false a的结果为5该程序使用到了短路逻辑运算符(&&),首先判断 a<4 的结果为 false,则 b 的结果必定是 false,所以不再执行第二个操作 a++<10 的判断,所以 a 的值为 5。
System . out . println ( " c = a + b = " + c ) ; c += a ; System . out . println ( " c += a = " + c ) ; c -= a ; System . out . println ( " c -= a = " + c ) ; c *= a ; System . out . println ( " c *= a = " + c ) ; a = 10 ; c = 15 ; c /= a ; System . out . println ( " c /= a = " + c ) ; a = 10 ; c = 15 ; c %= a ; System . out . println ( " c %= a = " + c ) ; c <<= 2 ; System . out . println ( " c <<= 2 = " + c ) ; c >>= 2 ; System . out . println ( " c >>= 2 = " + c ) ; c >>= 2 ; System . out . println ( " c >>= 2 = " + c ) ; c &= a ; System . out . println ( " c &= a = " + c ) ; c ^= a ; System . out . println ( " c ^= a = " + c ) ; c |= a ; System . out . println ( " c |= a = " + c ) ;
以上实例编译运行结果如下:
c = a + b = 30 c += a = 40 c -= a = 30 c *= a = 300 c /= a = 1 c %= a = 5 c <<= 2 = 20 c >>= 2 = 5 c >>= 2 = 1 c &= a = 0 c ^= a = 10 c |= a = 10条件运算符也被称为三元运算符。该运算符有3个操作数,并且需要判断布尔表达式的值。该运算符的主要是决定哪个值应该赋值给变量。
variable x = (expression) ? value if true : value if false以上实例编译运行结果如下:
Value of b is : 30 Value of b is : 20该运算符用于操作对象实例,检查该对象是否是一个特定类型(类类型或接口类型)。
instanceof运算符使用格式如下:
( Object reference variable ) instanceof (class/interface type) 如果运算符左侧变量所指的对象,是操作符右侧类或接口(class/interface)的一个对象,那么结果为真。 下面是一个例子:String name = "James"; boolean result = name instanceof String; // 由于 name 是 String 类型,所以返回真
如果被比较的对象兼容于右侧类型,该运算符仍然返回 true。
看下面的例子:
以上实例编译运行结果如下:
当多个运算符出现在一个表达式中,谁先谁后呢?这就涉及到运算符的优先级别的问题。在一个多运算符的表达式中,运算符优先级不同会导致最后得出的结果差别甚大。
例如,(1+3)+(3+2)*2,这个表达式如果按加号最优先计算,答案就是 18,如果按照乘号最优先,答案则是 14。
再如,x = 7 + 3 * 2;这里x得到13,而不是20,因为乘法运算符比加法运算符有较高的优先级,所以先计算3 * 2得到6,然后再加7。
下表中具有最高优先级的运算符在的表的最上面,最低优先级的在表的底部。
public class Car extends Vehicle { public static void main(String args[]){ Car c1 = new Car(); Vehicle v2 = new Car(); // v2 是 Car 类型 Vehicle v3 = new Vehicle(); //Car 是 Vehicle类型, Vehicle 不是 Car 类型 boolean result1 = c1 instanceof Vehicle; // true boolean result2 = v2 instanceof Car; // true boolean result3 = v2 instanceof Vehicle; // true boolean result4 = v3 instanceof Car; // false System.out.println(result1); System.out.println(result2); System.out.println(result3); System.out.println(result4);stinkaroo
190***276@qq.com
妇芳单身骗
lhm***@126.com
子类的实例可以声明为父类型,但父类的实例不能声明为子类型。
class Vehicle {} public class Car extends Vehicle { public static void main(String args[]){ Vehicle v1 = new Vehicle(); //父类型 Vehicle v2 = new Car(); //子类的实例可以声明为父类型 Car c1 = new Car(); // 子类型 Car c2 = new Vehicle(); //这句会报错,父类型的实例不能声明为子类型 //Car(子类)是Vehicle(父类)类型, Vehicle(父类)不是Car(子类)类型 boolean result1 = c1 instanceof Vehicle; // true boolean result2 = c1 instanceof Car; // true boolean result3 = v1 instanceof Vehicle; // true boolean result4 = v1 instanceof Car; // false boolean result5 = v2 instanceof Vehicle; // true boolean result6 = v2 instanceof Car; // true System.out.println(result1); System.out.println(result2); System.out.println(result3); System.out.println(result4); System.out.println(result5); System.out.println(result6);从执行结果来看,虽然 v2 被声明为了 Vehicle(父类),但它既是 instanceof Vehicle,又是 instanceof Car,所以 v2 其实是 Car(子类),否则 v2 instanceof Car 应该为 false。
无尘
227***8875@qq.com
_h0pe
286***6825@qq.com
cf
211***3262@qq.com
discovery
dis***ery131794@163.com
wen
l.z***16@qq.com
public class Opetator { public static void main(String[] args) { byte b = -1; short s = -1; int i = -1; long l = -1; System.out.println("byte b = " + b); System.out.println("(b >> 1) = " + (b >> 1)); System.out.println("(b >>> 1) = " + (b >>> 1)); System.out.println(String.format("hexof (b >> 1) = %x", (b >> 1))); System.out.println(String.format("hexof (b >>> 1) = %x", (b >>> 1))); System.out.println("short s = " + s); System.out.println("(s >> 1) = " + (s >> 1)); System.out.println("(s >>> 1) = " + (s >>> 1)); System.out.println(String.format("hexof (s >> 1) = %x", (s >> 1))); System.out.println(String.format("hexof (s >>> 1) = %x", (s >>> 1))); System.out.println("int i = " + i); System.out.println("(i >> 1) = " + (i >> 1)); System.out.println("(i >>> 1) = " + (i >>> 1)); System.out.println(String.format("hexof (i >> 1) = %x", (i >> 1))); System.out.println(String.format("hexof (i >>> 1) = %x", (i >>> 1))); System.out.println("long l = " + l); System.out.println("(l >> 1) = " + (l >> 1)); System.out.println("(l >>> 1) = " + (l >>> 1)); System.out.println(String.format("hexof (l >> 1) = %x", (l >> 1))); System.out.println(String.format("hexof (l >>> 1) = %x", (l >>> 1))); byte b = -1 (b >> 1) = -1 (b >>> 1) = 2147483647 hexof (b >> 1) = ffffffff hexof (b >>> 1) = 7fffffff short s = -1 (s >> 1) = -1 (s >>> 1) = 2147483647 hexof (s >> 1) = ffffffff hexof (s >>> 1) = 7fffffff int i = -1 (i >> 1) = -1 (i >>> 1) = 2147483647 hexof (i >> 1) = ffffffff hexof (i >>> 1) = 7fffffff long l = -1 (l >> 1) = -1 (l >>> 1) = 9223372036854775807 hexof (l >> 1) = ffffffffffffffff hexof (l >>> 1) = 7fffffffffffffff
1. byte、short、int 类型的右移操作都是先将左操作数转换为int类型,然后执行右移操作,结果也是int类型。
帅气的甘蔗 · 销量下滑只是雷克萨斯在华溃败的开始? 1 年前 |
大鼻子的消防车 · 12 神秘灵戒,在线教学-炼废通神-漫画牛 1 年前 |
气势凌人的可乐 · 电动屋YOUNG光小新,纯电续航40_懂车帝 1 年前 |