java入门---运算符&逻辑运算符&短路逻辑运算符&赋值运算符&条件运算符&instanceof 运算符

    这篇文章接着上次的来,主要看逻辑运算符&短路逻辑运算符&赋值运算符&条件运算符&instanceof 运算符这五种运算符。
html

    首先来看逻辑运算符。下表列出了逻辑运算符的基本运算,假设布尔变量A为真,变量B为假:java

 

操做符 描述 例子
&& 称为逻辑与运算符。当且仅当两个操做数都为真,条件才为真。 (A && B)为假。
| | 称为逻辑或操做符。若是任何两个操做数任何一个为真,条件为真。 (A | | B)为真。
称为逻辑非运算符。用来反转操做数的逻辑状态。若是条件为true,则逻辑非运算符将获得false。 !(A && B)为真。

    下面的简单示例程序演示了逻辑运算符。复制并粘贴下面的Java程序并保存为Test.java文件,而后编译并运行这个程序:express

public class Test {
  public static void main(String[] args) {
     boolean a = true;
     boolean b = false;
     System.out.println("a && b = " + (a&&b));
     System.out.println("a || b = " + (a||b) );
     System.out.println("!(a && b) = " + !(a && b));
  }
}

spa

    运行结果为:.net

 

a && b = false a || b = true !(a && b) = true

    当使用与逻辑运算符时,在两个操做数都为true时,结果才为true,可是当获得第一个操做为false时,其结果就一定是false,这时候就不会再判断第二个操做了。code

public class LuoJi{
    public static void main(String[] args){
        int a = 5;//定义一个变量;
        boolean b = (a<4)&&(a++<10);
        System.out.println("使用短路逻辑运算符的结果为"+b);
        System.out.println("a的结果为"+a);
    }
}

htm

    运行结果为:对象

 

使用短路逻辑运算符的结果为false a的结果为5

    该程序使用到了短路逻辑运算符(&&),首先判断 a<4 的结果为 false,则 b 的结果一定是 false,因此再也不执行第二个操做 a++<10 的判断,因此 a 的值为 5。blog

    而后来看赋值运算符。下面是Java语言支持的赋值运算符:接口

 

操做符 描述 例子
= 简单的赋值运算符,将右操做数的值赋给左侧操做数 C = A + B将把A + B获得的值赋给C
+ = 加和赋值操做符,它把左操做数和右操做数相加赋值给左操做数 C + = A等价于C = C + A
- = 减和赋值操做符,它把左操做数和右操做数相减赋值给左操做数 C - = A等价于C = C -
 A
* = 乘和赋值操做符,它把左操做数和右操做数相乘赋值给左操做数 C * = A等价于C = C * A
/ = 除和赋值操做符,它把左操做数和右操做数相除赋值给左操做数 C / = A等价于C = C / A
(%)= 取模和赋值操做符,它把左操做数和右操做数取模后赋值给左操做数 C%= A等价于C = C%A
<< = 左移位赋值运算符 C << = 2等价于C = C << 2
>> = 右移位赋值运算符 C >> = 2等价于C = C >> 2
&= 按位与赋值运算符 C&= 2等价于C = C&2
^ = 按位异或赋值操做符 C ^ = 2等价于C = C ^ 2
| = 按位或赋值操做符 C | = 2等价于C = C | 2

    下面的简单示例程序演示了赋值运算符。复制并粘贴下面的Java程序并保存为Test.java文件,而后编译并运行这个程序:

public class Test {
  public static void main(String[] args) {
     int a = 10;
     int b = 20;
     int c = 0;
     c = a + b;
     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 >>= a = " + c );
     c &= a ;
     System.out.println("c &= 2  = " + 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
public class Test {
   public static void main(String[] args){
      int a , b;
      a = 10;
      // 若是 a 等于 1 成立,则设置 b 为 20,不然为 30
      b = (a == 1) ? 20 : 30;
      System.out.println( "Value of b is : " +  b );
 
      // 若是 a 等于 10 成立,则设置 b 为 20,不然为 30
      b = (a == 10) ? 20 : 30;
      System.out.println( "Value of b is : " + b );
   }
}

    运行结果为:

 

Value of b is : 30 Value of b is : 20

    再来就是instanceof 运算符。该运算符用于操做对象实例,检查该对象是不是一个特定类型(类类型或接口类型)。instanceof运算符使用格式以下:

 

( Object reference variable ) instanceof (class/interface type)

    若是运算符左侧变量所指的对象,是操做符右侧类或接口(class/interface)的一个对象,那么结果为真。下面是一个例子:

 

String name = "James"; boolean result = name instanceof String; // 因为 name 是 String 类型,因此返回真

    若是被比较的对象兼容于右侧类型,该运算符仍然返回true。看下面的例子:

 

class Vehicle {}
 
public class Car extends Vehicle {
   public static void main(String[] args){
      Vehicle a = new Car();
      boolean result =  a instanceof Car;
      System.out.println( result);
   }
}

    运行结果为:
true
    当多个运算符出如今一个表达式中,谁先谁后呢?这就涉及到运算符的优先级别的问题。在一个多运算符的表达式中,运算符优先级不一样会致使最后得出的结果差异甚大。例如,(1+3)+(3+2)*2,这个表达式若是按加号最优先计算,答案就是 18,若是按照乘号最优先,答案则是 14。再如,x = 7 + 3 * 2;这里x获得13,而不是20,由于乘法运算符比加法运算符有较高的优先级,因此先计算3 * 2获得6,而后再加7。下表中具备最高优先级的运算符在的表的最上面,最低优先级的在表的底部:
类别 操做符 关联性
后缀 () [] . (点操做符) 左到右
一元 + + - !〜 从右到左
乘性  * /% 左到右
加性  + - 左到右
移位  >> >>>  <<  左到右
关系  >> = << =  左到右
相等  ==  != 左到右
按位与 左到右
按位异或 ^ 左到右
按位或 | 左到右
逻辑与 && 左到右
逻辑或 | | 左到右
条件 ?: 从右到左
赋值 = + = - = * = / =%= >> = << =&= ^ = | = 从右到左
逗号 左到右
    说一些题外话哈,在判断一个实例引用的类型时,使用的是实际类型,而不是声明的类型。在下面的代码中:
Vehicle v2 = new Car();    // v2 是 Car 类型
    v2 是 Car 类型,而不是 Vehicle 类型:
class Vehicle {} 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); } }
    子类是父类的类型,但父类不是子类的类型。子类的实例能够声明为父类型,但父类的实例不能声明为子类型:
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。
    好啦,此次就到这里了。若是感受不错的话,请多多点赞支持哦。。。


  原文连接: https://blog.csdn.net/luyaran/article/details/80109176
相关文章
相关标签/搜索