資料型別與運算子
- 馮·諾伊曼體系結構
- 變數及其用法和命名
- 整形變數(int)
- 長整型變數(long)
- 雙精度浮點型變數(double)
- 單精度浮點型變數(float)
- 字符型變數(char)
- 布爾型別變數(boolean)
- 字串型別變數(String)
- 變數的命名規則
- 總結
- 數值提升
- 運算子
- 除法
- 取模
- 關系運算子
- 邏輯運算子
- 位運算子
- 移位運算子
- 條件運算子
馮·諾伊曼體系結構
在本篇文章的開頭,我給大家介紹一個很偉大的人物:馮·諾伊曼,相信很多人都聽過,馮·諾依曼(John von Neumann,1903~1957),20世紀最重要的數學家之一,在現代計算機、博弈論、核武器和生化武器等諸多領域內有杰出建樹的最偉大的科學全才之一,被后人稱為“計算機之父”和“博弈論之父”,

馮·諾依曼體系結構
本篇博客我們所討論的 “變數” 主要和我們的 “記憶體” 這樣的硬體設備密切相關,
變數及其用法和命名
變數指的是程式運行時可變的量. 相當于開辟一塊記憶體空間來保存一些資料,
型別則是對變數的種類進行了劃分, 不同的型別的變數具有不同的特性,
整形變數(int)
基本語法
代碼示例:
int num = 20
System.out.println(num) ;
Java中定義一個變數的方法和C語言中大同小異,只是在Java中列印一個變數用到了System.out.println()(可輸入sout快捷鍵)
注意:
在Java中int型別的大小永遠是4個位元組,不受計算機是多少位平臺所影響,這體現了Java的跨平臺性和可移植性
長整型變數(long)
和整形變數用法基本一致:
long num = 20L; //
但要注意定義一個長整型變數時, 初始值要寫作 10l 也可以(小寫的 L, 不是數字1),如果什么都不寫的話型別就是整形了,
雙精度浮點型變數(double)
用法和C語言中的double用法一致,值得注意的有:
1.進行除法運算時,如果兩邊都為整形,則計算出的結果一定為整形:
int a = 1;
int b = 2;
System.out.println(a / b);
// 執行結果
0
若要使結果帶有小數,則除號兩邊至少有一個小數:
double a = 1.0;
double b = 2.0;
System.out.println(a / b);
// 執行結果
0.5
2.
在Java中此代碼輸出的結果為
因為在Java中double型別的精度并不明確,所以在計算某些值時勢必會存在一定誤差
單精度浮點型變數(float)
float f = 12.5;
上述的寫法是錯誤的!!!
因為C語言是弱型別的語言,對型別的檢查并不嚴格,因此在C語言中這么寫是正確的,但由于Java是強型別語言,對型別的檢查比較嚴格,小數默認是double型別的,因此在Java中這么寫是錯誤的,要想改進,第一種方法就是在小數后加個f/F(讓他變成float型別),第二種就是強制型別轉換,
這也體現了Java的安全性
字符型變數(char)
表示方法:
char ch = 'A';
System.out.println(ch);
注意:Java中字符char型別占2個位元組,能表示漢字,但不能表示負數,
布爾型別變數(boolean)
代碼示例:
boolean value = true;
System.out.println(value);
注意:
- boolean 型別的變數只有兩種取值, true 表示真, false 表示假.
- Java 的 boolean 型別和 int 不能相互轉換, 不存在 1 表示 true, 0 表示 false 這樣的用法.
- boolean 型別有些 JVM 的實作是占 1 個位元組, 有些是占 1 個位元位, 這個沒有明確規定.
- 布爾型別由于其本身所代碼的特殊含義,boolean型別與其他基本型別不能進行型別的轉換(既不能進行自動型別的提升,也不能強制型別轉換), 否則,將編譯出錯,
字串型別變數(String)
有別于C語言,在Java中定義一個字串型別變數后的列印方法為:
String name = "zhangsan";
System.out.println(name);
在列印時還可以使用加號進行字串的拼接:

列印的結果為:
同時,也可以對整數進行拼接:

執行的結果為:

變數的命名規則
- 一個變數名只能包含數字, 字母, 下劃線,不能包括**.**(點號),
- 數字不能開頭,
- 變數命名推薦小駝峰命名法,當一個變數名由多個單詞構成的時候,除了第一個單詞之外,其他單詞首字母都大寫;另外,變數在命名時最好不要使用拼音,也不能使用關鍵字命名!
注意: 雖然語法上也允許使用中文/美元符($)命名變數,但是不推薦這樣做,因為在有些企業中是禁止使用此符號的
附Java中常見關鍵字:

總結

數值提升
無需多記,只需記住以下兩點即可:
- 不同型別的資料混合運算,范圍小的會提升成范圍大的,
- 對于short,byte等比4個位元組小的型別,會先提升成4個位元組的int,再運算,

因此,在必要的時候,要強制型別轉換
運算子
整體來說,Java之中的運算子和C語言中的運算子用法是基本一樣的,但也需注意有些細節,下面我會給大家詳細介紹比較重要的部分:
除法
不管在C語言還是Java當中,除法都是一個非常易錯的運算,下面,給大家看一組例題:
大家可以自己先算一下答案奧!

那么,接下來就揭曉答案啦:

是不是和你算的一樣呢?只要注意float所修飾的具體內容,就可以很輕松得算出來啦!
取模
除了除法以外,取模也是一個比較易錯的演算法,因為大家都有了C語言的基礎,那么就不再多說其用法啦,直接上題!
同樣,此題也不難,只需要大家注意注意符號即可搞定!答案為:
==值得注意的是,%表示取余,不僅僅可以對 int 求模,也能對double來求模,例:
System.out.println(11.5 % 2.0);
// 運行結果
1.5
關系運算子
關系運算子主要有6種:== != < > <= >=
值得注意的是,關系運算子運算式的回傳值都是布爾型別,不能單純地只在輸出里面輸出某個數值,例:
System.out.println(6);
此種寫法是錯誤的,因為在Java中不存在0是假,非0是真,而只有true和false,因此,只能寫為:
int a=10;
int b=20;
System.out.println(a<b);
輸出的結果為true!
邏輯運算子
邏輯運算子主要有三個:
&& || !
和C語言中邏輯運算子的用法基本一致,但需注意的是:邏輯運算子的運算元(運算元往往是關系運算子的結果)和回傳值都是 boolean,同時,也符合C語言之中短路求值的情況
和C中不同的是,Java中有& 和 |兩種運算子,此兩種運算子在這里并不推薦大家使用,因為沒有短路求值的情況,在某些情況下很容易出錯,例:
System.out.println(10 > 20 & 10 / 0 == 0); // 程式拋出例外
System.out.println(10 < 20 | 10 / 0 == 0); // 程式拋出例外
位運算子
位運算子主要有四個:
& | ~ ^
注意:
- 0x 前綴的數字為十六進制數字,十六進制可以看成是二進制的簡化表示方式,一個十六進制數字對應 4 個二進
制位, - 0xf 表示10進制的15,也就是二進制的 1111
- printf 能夠格式化輸出內容,%x 表示按照十六進制輸出.
- \n 表示換行符
其他地方和C中也是一樣的,都是對數值的二進制位進行操作的!
移位運算子
移位運算子有三個:
<< >> >>>
注意:
- 左移1位, 在右邊補0,相當于原數字 * 2,左移N位,相當于原數字*2的N次方
- 右移1位, 在左邊補符號位,相當于原數字 / 2,右移 N 位,相當于原數字 / 2 的N次方
- 由于計算機計算移位效率高于計算乘除,當某個代碼正好乘除 2 的N次方的時候可以用移位運算代替
- 移動負數位或者移位位數過大都沒有意義
需要注意,
在Java中有一個無符號右移運算子:>>>,在左邊統一補0!但是沒有無符號左移運算子!
條件運算子
條件運算子只有一個:
運算式1 ? 運算式2 : 運算式3(布爾運算式),例:
// 求兩個整數的最大值
int a = 10;
int b = 20;
int max = a > b ? a : b;
同時,在這里給大家分享一個比較有趣的題:
System.out.println(false==false?(true==true?false:true):true);
此代碼輸出結果為false,原因是第一步中false是等于false的,所以執行冒號前面的陳述句,又因為true和true是相等的,所以再執行冒號前面的,即列印false!!!
到這里,Java中比較重要的運算子知識都講完啦,大家是不是識訓了很多呢?運算子這里不難,就是需要記住一點語法,所以希望大家自己利用空閑時間多記記多練練,相信會進步非常明顯的!

轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/272880.html
標籤:java
