天天看點

Java基礎文法(總結篇)

關鍵字&辨別符

關鍵字的概念與特征

概念:Java關鍵字是事先定義好的對Java的編譯器有特殊的意義,他們用來表示一種資料類型,或者表示程式的結構等,關鍵字不能用作變量名、方法名、類名、包名和參數。

特征:

  • 完全小寫
  • 在增強版記事本中(例如Notepad++)有特殊顔色

辨別符的概念與規則

  1.   什麼是辨別符?

    凡是可以由自己命名的地方都稱為辨別符.

    例: 項目名 ,包名 ,類名 .方法名

        2.   命名規範

    ①    不可使用java關鍵字和保留字,但是可以包含關鍵字和保留字.

    ②    可以使用26個字母大小寫,數字0-9,$和_.

    ③    可以使用數字,但不可放在首位.

    ④    長度理論上沒有限制,但命名最好能反映出其作用,遵循”駝峰形式”,見命知意

    ⑤    包名全部小寫,類名全部大駝峰式

    ⑥    變量名、方法名首字母小寫,如果名稱由多個單詞組成,每個單詞的首字母都要大寫

              ⑦ 常量(特指被 final 修飾的常量)名全部大寫,如果是單個字母,需要大寫,如果是多個單詞,需要用下劃線分開。并且都大寫

    例:寫一個ajax的項目執行個體,

    項目名:ajaxtest        包名:com.liu.ajax       類名:AjaxDemo

常量&變量

常量的概念:在程式運作期間。固定不變的量。

常量的分類:

  1. 字元常量:凡是用單引号引起來的單個字元,就做字元常量。例如:、‘b'、9’、‘中

  2. 字元串常量:凡是用雙引号引起來的部分,叫做字元串常量。例如:"abc"、"Hello”、“123"

  3. 整數常量:直接寫上的數字,沒有小數點。例如:100、200、0、-250

  4. 浮點數常量:直接寫上的數字,有小數點。例如:2.5、-3.14、0.0 

  5. 布爾常量:隻有兩種取值 true  |  false

基本資料類型:

           類型                                                                                                 位元組數                       二進制位數

          byte (位元組型)                                                                                   1                                   8

          short(短整型)                         char    (字元型)                             2                                  16

          int    (整型)                            float    (單精度浮點數)                   4                                  32

         long  (長整型)                        double(雙精度浮點數)                   8                                   64

注意事項:
  • Java中的預設類型:整數類型是 int 、浮點類型是double
  • 資料範圍與位元組數不一定相關,例如float資料範圍比 long 更加廣泛,但是float是4位元組,1ong是8位元組。
  • 浮點型可能隻是一個近似值,并非精确的值。
  • 浮點數當中預設類型是double。如果一定要使用float類型,需要加上一個字尾F。
  • 字元串不是基本類型,而是引用類型
  • 如果是整數,預設為int類型,如果一定要使用long類型,需要加上一個字尾L。推薦使用大寫字母字尾。

 變量: 程式運作期間,内容可以改變的量。

建立一個變量并且使用的格式:

  資料類型  變量名稱; //建立了一個變量

  變量名稱 = 資料值;  //指派,将右邊的資料值,指派交給左邊的變量

一步到位的格式:

  資料類型  變量名稱 = 資料值; //在建立一個變量的同時,立刻放入指定的資料值

 注意事項:

  1.如果建立多個變量,那麼變量之間的名稱不可以重複。

   2.對于float和long類型來說,字母字尾F 和 L不要丢掉。

   3.沒有進行指派的變量,不能直接使用;一定要指派之後,才能使用。

作用域 : 從定義變量的一行開始,一直到直接所屬的大括号結束。 

資料類型轉換

當效據類型不一樣時,就會發生資料類型轉換

自動類型轉換(隐式)

  1.特點:代碼不需要進行特殊處理,自動完成

  2.規則:資料範圍從小到大

long num1 = 100;
System.out.println(num1)      

 // 左邊是long類型,右邊是預設的int類型,左右不一樣

 // int-->long,符合了資料範圍從小到大的要求

強制類型轉換(顯式)

   1.特點:代碼需要進行特殊的格式處理,不能自動完成

   2.格式:範圍小的類型範圍小的變量名=(範圍小的類型)原本範圍大的資料

int num=(int)100L;
System.out.print1n(num);      

 //左邊是int類型,右邊是long類型,不一樣

 //格式範圍小的類型  範圍小的變量名 =(範圍小的類型) 原本範圍大的資料 ;

  1.強制類型轉換一般不推薦使用,因為有可能發生精度損失、資料溢出。

  2.byte / short / char這三種類型都可以發生數學運算,例如加法“+”.

  3.byte/short/char這三種類型在運算的時候,都會被首先向上提升成為int類型,然後再計算。符合ASCII編碼表。 

例3:byte num4 = 40;//注意!右側的數值大小不能超過左側的類型範圍byte num5 = 50;//當byte + byte,會先向上提升稱為int類型,是以結果就是--> int + int  ,傳回類型也應該是int
int result1 = num4 + num5;
System.out.println(result1);//90      

 運算符 :進行特定操作的符号。例如:+

 表達式:用運算符連起來的式子叫做表達式。例如:20+5 。   又例如:a+b

 四則運算:加+      減 -      乘 *      除  /

  取模(取餘數):%

 隻有對于整數的除法來說,取模運算符才有餘數的意義。

int x = 10;
int y = 3;
int resultl = x / y ;
System.out.println(result1);//3
int result2 = x % y ;
System.out.println(result2);//餘數,模,1      

 算術運算符

Java基礎文法(總結篇)

 四則運算當中的加号“+”有常見的三種用法:

  1.對于數值來說,+ 就是加法。

  2.對于字元char類型來說,在計算之前,char會被提升成為int,然後再計算。

  char類型字元,和int類型數字,之間的對照關系表:ASCII、Unicode

  3.對于字元串String來說,+ 代表字元串連接配接操作。   () 小括号的優先級最高

例3:
String str = "Java";
//String + int --> String
System.out.println(str2+20);//Java20      

自增運算符:++

  例如:   a++;   先使用a值,再執行a = a + 1 ; 

int a = 1;int b = 2;
b = a++;  //在這一步,a的值還沒有改變,是以是将a=1的值賦給了b,然後再進行改變。System.out.println("a:"+a); //a:2System.out.println("b:"+b); //b:1      

自減運算符:- -

  例如:   ++a; 先執行a = a + 1 ; 再使用a值。

int a = 1;int b = 2;
b = --a;
System.out.println("a:"+a);
System.out.println("b:"+b);      

a++ : 在變量值被使用之後才增加的值

++a : 在變量值在被使用之前增加它的值

- - 操作符的工作原理與此相同,隻是它所執行的是減值操作而非增值操作。

 指派運算符

指派運算符是指為變量或常量指定數值的符号。如可以使用 “=” 将右邊的表達式結果賦給左邊的操作數。

Java 支援的常用指派運算符,如下表所示:

Java基礎文法(總結篇)

 比較運算符

比較運算符用于判斷兩個資料的大小,例如:大于、等于、不等于。比較的結果是一個布爾值( true 或 false )。

Java 中常用的比較運算符如下表所示:

Java基礎文法(總結篇)

  1、  > 、 < 、 >= 、 <= 隻支援左右兩邊操作數是數值類型

  2、  == 、 != 兩邊的操作數既可以是數值類型,也可以是引用類型

邏輯運算符

主要用于進行邏輯運算,連接配接兩個Boolean值,代表兩個條件。

Java 中常用的邏輯運算符如下表所示:

Java基礎文法(總結篇)

我們可以從“投票選舉”的角度了解邏輯運算符:

  1、 與:要求所有人都投票同意,才能通過某議題

  2、 或:隻要求一個人投票同意就可以通過某議題

  3、 非:某人原本投票同意,通過非運算符,可以使其投票無效

  4、 異或:有且隻能有一個人投票同意,才可以通過某議題

當使用邏輯運算符時,我們會遇到一種很有趣的 “短路” 現象    >> 如果根據左邊已經可以判斷得到最終結果,那麼右邊的代碼将不再執行,進而節省一定的性能。

譬如:( 1 > 2 ) && ( 1 < 3 ) 中,如果能确定左邊 1 > 2 運作結果為 false , 則系統就認為已經沒有必要執行右側的 1 < 3 啦。

條件運算符

條件運算符( ? : )也稱為 “三元運算符”。

  • 一進制運算符:隻需要一個資料就可以進行操作的運算符。例如:取反!、自增++、自減--
  • 二進制運算符:需要兩個資料才可以進行操作的運算符。例如:加法+、指派=
  • 三元運算符:需要三個資料才可以進行操作的運算符。

文法形式:布爾表達式 ? 表達式1 :表達式2

運算過程:如果布爾表達式的值為 true ,則傳回 表達式1 的值,否則傳回 表達式2 的值

例如 :

Java基礎文法(總結篇)

 因為,表達式 8>5 的值為 true ,是以,傳回: 8大于5

方法 ♦ ♦

所謂方法,就是用來解決一類問題的代碼的有序組合,是一個功能子產品。

一般情況下,定義一個方法的文法是:  

通路修飾符  傳回值類型  方法名(參數清單){

  方法體

}

 其中:

  1、 通路修飾符:方法允許被通路的權限範圍, 可以是 public、protected、private 甚至可以省略 ,其中 public 表示該方法可以被其他任何代碼調用

  2、 傳回值類型:方法傳回值的類型,如果方法不傳回任何值,則傳回值類型指定為 void ; 如果方法具有傳回值,則需要指定傳回值的類型,并且在方法體中使用 return 語句傳回值

  3、 方法名:定義的方法的名字,必須使用合法的辨別符

  4、 參數清單:傳遞給方法的參數清單,參數可以有多個,多個參數間以逗号隔開,每個參數由參數類型和參數名組成,以空格隔開 

 根據方法是否帶參、是否帶傳回值,可将方法分為四類:

   無參無傳回值方法

  如果方法不包含參數,且沒有傳回值,我們稱為無參無傳回值的方法。

  方法的使用分兩步:

  第一步,定義方法

  例如:下面代碼定義了一個方法名為 show ,沒有參數,且沒有傳回值的方法,執行的操作為輸出 “ welcome to imooc. ”

  

Java基礎文法(總結篇)

 注意 :

  1、 方法體放在一對大括号中,實作特定的操作

  2、 方法名主要在調用這個方法時使用,需要注意命名的規範,一般采用第一個單詞首字母小寫,其它單詞首字母大寫的形式

  第二步,調用方法

  當需要調用方法執行某個操作時,可以先建立類的對象,然後通過  對象名.方法名();  來實作

  例如:在下面的代碼中,我們建立了一個名為 hello 的對象,然後通過調用該對象的 show( ) 方法輸出資訊

  

Java基礎文法(總結篇)

  運作結果為:  welcome to imooc.

  無參帶傳回值方法

  如果方法不包含參數,但有傳回值,我們稱為無參帶傳回值的方法。

  例如:下面的代碼,定義了一個方法名為 calSum ,無參數,但傳回值為 int 類型的方法,執行的操作為計算兩數之和,并傳回結果

Java基礎文法(總結篇)

    在 calSum( ) 方法中,傳回值類型為 int 類型,是以在方法體中必須使用 return 傳回一個整數值

  調用帶傳回值的方法時需要注意,由于方法執行後會傳回一個結果,是以在調用帶傳回值方法時一般都會接收其傳回值并進行處理。如下:第6行

Java基礎文法(總結篇)

  運作結果為: 兩數之和為:17

 不容忽視的“小陷阱”:

  1、 如果方法的傳回類型為 void ,則方法中不能使用 return 傳回值!

Java基礎文法(總結篇)

  2、 方法的傳回值最多隻能有一個,不能傳回多個值

Java基礎文法(總結篇)

  3、 方法傳回值的類型必須相容,例如,如果傳回值類型為 int ,則不能傳回 String 型值

Java基礎文法(總結篇)

   帶參無傳回值方法

 有時方法的執行需要依賴于某些條件,換句話說,要想通過方法完成特定的功能,需要為其提供額外的資訊才行。

 例如,現實生活中電飯鍋可以實作“煮飯”的功能,但前提是我們必須提供食材,如果我們什麼都不提供,那就真是的“巧婦難為無米之炊”了。

 我們可以通過在方法中加入參數清單接收外部傳入的資料資訊,參數可以是任意的基本類型資料或引用類型資料。

 我們先來看一個帶參數,但沒有傳回值的方法:

 

Java基礎文法(總結篇)

  上面的代碼定義了一個 show 方法,帶有一個參數 name ,實作輸出歡迎消息。

  調用帶參方法與調用無參方法的文法類似,但在調用時必須傳入實際的參數值

Java基礎文法(總結篇)

 例如:

Java基礎文法(總結篇)

  運作結果為: 歡迎您,愛慕課!

  很多時候,我們把定義方法時的參數稱為形參,目的是用來定義方法 需要傳入參數的個數和類型;把調用方法時的參數稱為實參,是傳遞給方法真正被處理的值。

  一定不可忽視的問題:

  1、 調用帶參方法時,必須保證明參的數量、類型、順序與形參一一對應

Java基礎文法(總結篇)

2、 調用方法時,實參不需要指定資料類型,如 

Java基礎文法(總結篇)

  3、 方法的參數可以是基本資料類型,如 int、double 等,也可以是引用資料類型,如 String、數組等           

Java基礎文法(總結篇)

                         第10行,Array.toString()方法将數組轉換為字元串輸出

 4、 當方法參數有多個時,多個參數間以逗号分隔

Java基礎文法(總結篇)

 帶參帶傳回值方法

  如果方法既包含參數,又帶有傳回值,我們稱為帶參帶傳回值的方法。

  例如:

下面的代碼,定義了一個 show 方法,帶有一個參數 name ,方法執行後傳回一個 String 類型的結果

Java基礎文法(總結篇)

調用帶參帶傳回值的方法: