首頁技術文章正文

什么是Java運算?Java運算好學嗎?

更新時間:2022-11-24 來源:黑馬程序員 瀏覽量:

提到運算,你可能會立即想到加、減、乘、除四則運算以及“九九乘法表”。Java 語言中有很多進行數據運算的方式,比如:算術運算、比較運算、邏輯運算、賦值運算、三目運算等。每一種運算方式,又都包含了很多的運算符,小編把這些運算符形象的稱為“十八般武藝”,學習 Java 中的運算,就是學習這些運算符的使用,也就是修煉這“十八般武藝”的過程。



public class Test{
   public static void main(String[] args) {
       int number = 1 + 2; // 使用加號(+)將常量1和2連接起來,構成了一個加法表達式,并把運算結果賦值給變量number
       System.out.println(number); // 輸出number的值
  }
}

上面的式子就是使用運算符加號(+)將常量 1 和 2 連接起來,構成了一個加法表達式,并把運算結果賦值給變量 number,不出意外的話,打印結果應該是:

public class Test{
   public static void main(String[] args) {
       int number = 1 + 2; // 使用加號(+)將常量1和2連接起來,構成了一個加法表達式,并把運算結果賦值給變量number
       System.out.println(number); // 輸出number的值
       int count = number + 10; // 變量和常量同時參與運算
       System.out.println(count); // 輸出計算結果
  }
}

打印結果:

13

除此之外,運算的方式也有很多,加法、減法、取余(取模)、比較運算等等,但它們都有一個共同的特點:每個表達式都會有一個運算結果。我們根據表達式運算結果的數據類型,將表達式的類型進行歸納分類,比如:

整型表達式:運算結果為整數。比如: 1 + 2、10 * 20、5 - 3,它們的運算結果都是整數
浮點型表達式:運算結果為浮點數。比如:3.14 * 2、0.618 + 0.382、3.0 / 1,它們的運算結果都是浮點數
布爾型表達式:運算結果為布爾類型的值。比如:2 > 1、(20-10) < 15,它們的運算結果都是布爾型:要么true、要么false。
練好了運算符、表達式的基本功,現(xiàn)在,我們可以開始學習真正的武藝了。

算術運算

先來幾個簡單的招式,好好復習我們小學時期的算術運算。Java 中的算術運算符【大概、也許】有七種:

1669213255528_2.png

前面四個運算符還算常見:+、 -、 *、 / ,雖然乘號(*)和除號(/)跟我們以前見到的長得不一樣,但并不難理解。百分號(%)在這里是“取余”、“取余”的意思,也就是說,使用百分號(%)可以得到數字 7 除以 3 之后的余數:1。而 ++ 和 -- 就比較陌生了,它們分別代表數據 “自增1” 和 “自減1”,這種運算是我們以前沒見過的,接下來,我手把手教你每個招式——運算符的用法。

1、加、減、乘、除

四則運算的用法,代碼如下:

public class Test{
   public static void main(String[] args) {
       int num1 = 3;
       int num2 = 4;
       int num3 = 5;
       int num4 = 10;
       // 1.加法運算
       int add = num1 + num2;
       // 2.減法運算
       int subtract = num2 - num1;
       // 3.乘法運算
       int multiply = num2 * num3;
       // 4.除法運算
       int divide = num4 / num3;
       // 分別輸出運算結果
       System.out.println(add); // 輸出加法計算結果
       System.out.println(subtract); // 輸出減法計算結果
       System.out.println(multiply); // 輸出乘法計算結果
       System.out.println(divide); // 輸出除法計算結果
  }
}

輸出結果:

7
1
20
2

除法運算有個細節(jié)要注意:如果相除的兩個數進行運算,除不盡怎么辦?猜想一下,下面這個行代碼會得到什么結果:

System.out.println(7 / 3); // 即 7 / 3,結果是什么,2.333...還是2,還是1

看結果:

public class Test{
  public static void main(String[] args) {
  System.out.println(7 / 3);
  }
}

切記一點:除法運算符( / ),得到兩個數據相除的商,在 Java 語言中,整數除以整數結果還是整數,如果除不盡,會舍棄余數。也就是說,7 / 3 的商是2,余數為1,因為參與運算的被除數、除數都是整數(int類型),所以計算結果還是整數,舍棄了余數部分,結果是2。

是不是有一種恍然大悟的感覺。這是 Java 中的運算與我們以前的認知第一個不一樣的地方。

2、取模、自增(++)和自減(--)

再教你三個進階招式(%、 ++、 --):

public class Test{
   public static void main(String[] args) {
       int num1 = 3;
       int num2 = 4;
       int num3 = 5;
       int num4 = 10;
       int remainder = num3 % num1; // 取模/取余運算,5對3取模,結果是?
       System.out.println(remainder); // 輸出取模運算結果
       num2++; // num2自增1
       num4--; // num4自減1
       System.out.println(num2); // 輸出自增之后的運算結果
       System.out.println(num4); // 輸出自減之后的運算結果
  }
}

輸出結果:

2
5
9

百分號(%)是取模運算,也叫取余運算,是除法運算的一種擴展,只不過除法運算得到的結果是商,而取模運算得到的結果是余數。如果兩個數進行取模運算,結果是0,意味著什么?沒錯,這就是整除的效果,所以,取模運算(%)可以用來判斷兩個數是否能夠整除,也就是說,被除數是除數的倍數。

加加(++)和減減(--)運算是讓變量進行自增或自減。這里要注意,不能將這兩個運算符直接使用到常量上,比如下面的代碼是錯誤的:

1++; // 不允許常量自增或自減

思考一下,為什么?那是因為常量的概念,規(guī)定了它不能夠被修改,所以,如果你想要獲得2,那么直接使用字面值常量2就行了,完全不需要使用另一個常量進行運算。還有個細節(jié),上面的代碼,也可以把 ++ 和 -- 放到變量的前面,這樣的運算結果是一樣的(放在變量前、后的代碼不能同時存在,否則數據會進行兩次運算哦):
來,我們試試把++和--寫到前面

++num2; // num2自增1
--num4; // num4自減1
public class Test{
   public static void main(String[] args) {
       int num1 = 3;
       int num2 = 4;
       int num3 = 5;
       int num4 = 10;
       int remainder = num3 % num1; // 取模/取余運算,5對3取模,結果是?
       System.out.println(remainder); // 輸出取模運算結果
       // num2++; // num2自增1
// num4--; // num4自減1
++num2; // num2自增1
--num4; // num4自減1
       System.out.println(num2); // 輸出自增之后的運算結果
       System.out.println(num4); // 輸出自減之后的運算結果
  }
}

輸出結果沒有變化:

5
9

當然,加加(++)和減減(--)也可以像別的運算符那樣,把結果賦值給一個新的變量,就像這樣:

public class Test{
   public static void main(String[] args) {
       int num1 = 3;
       int num2 = 4;
       int num3 = 5;
       int num4 = 10;
       int num5 = num2++; // 猜想:num2自增1,然后賦值給新變量num5
int num6 = num4--; // 猜想:num4自減1,然后賦值給新變量num6
System.out.println(num5); // 輸出自增之后的運算結果
System.out.println(num6); // 輸出自減之后的運算結果
  }
}

輸出結果:

4
10

怎么還是原來的值?難道是沒有發(fā)生運算?

看來我們的猜想不正確,原來

int num5 = num2++; // 結論:num2先賦值給新變量num5,然后才進行自增運算
int num6 = num4--; // 結論:num4先賦值給新變量num6,然后才進行自減運算

我把加加(++)和減減(--)放到變量前面試試:

public class Test{
   public static void main(String[] args) {
       int num1 = 3;
       int num2 = 4;
       int num3 = 5;
       int num4 = 10;
// int num5 = num2++; // 結論:num2先賦值給新變量num5,然后才進行自增運算
// int num6 = num4--; // 結論:num4先賦值給新變量num6,然后才進行自減運算
int num5 = ++num2; // 猜想:num2自增1,然后賦值給新變量num5
int num6 = --num4; // 猜想:num4自減1,然后賦值給新變量num6
       System.out.println(num5); // 輸出自增之后的運算結果
       System.out.println(num6); // 輸出自減之后的運算結果
  }
}

輸出結果:

5
9

終于變成正確答案了:

int num5 = ++num2; // 結論:num2自增1,然后賦值給新變量num5
int num6 = --num4; // 結論:num4自減1,然后賦值給新變量num6

但是,這是為什么呢?加加(++)和減減(--)放到變量前和放到變量后為什么結果不一樣,到底數據有沒有進行運算呢?剖析一下這兩招:

單獨使用:放在變量前或后結果一樣

參與其它運算:

 在變量前,先自增(自減) ,再進行其它運算

 在變量后,先以原值進行其它運算,再自增(自減)

所以,第一次把 ++ 和 -- 放在變量后,是把變量原來的值賦值給新變量,而自增(或自減)的值被拋棄了,因此打印的是原來的值;第二次把 ++ 和 -- 放在變量前,是把運算之后的值賦值給新變量,因此打印的是計算之后的數據,這就是加加(++)和減減(--)這兩個運算符的底層原理。 ++ 和 -- 是一種特殊的運算,這是再一次不同于我們以往認知的一個地方。


分享到:
在線咨詢 我要報名
和我們在線交談!