java基礎之方法詳解
JAVA 異常分類及處理

異常分類
Throwable 是 Java 語言中所有錯誤或異常的超類。下一層分為 Error 和 Exception
Error
1. Error 類是指 java 運行時系統(tǒng)的內(nèi)部錯誤和資源耗盡錯誤。應用程序不會拋出該類對象。如果 出現(xiàn)了這樣的錯誤,除了告知用戶,剩下的就是盡力使程序安全的終止。
Exception ( RuntimeException、CheckedException )
2. Exception 又有兩個分支,一個是運行時異常 RuntimeException ,一個是 CheckedException。
RuntimeException 如 : NullPointerException 、 ClassCastException ;一個是檢查異常 CheckedException,如 I/O 錯誤導致的 IOException、SQLException。 RuntimeException 是 那些可能在 Java 虛擬機正常運行期間拋出的異常的超類。 如果出現(xiàn) RuntimeException,那么一 定是程序員的錯誤. 13/04/2018
Page 102 of 283
檢查異常 CheckedException :一般是外部錯誤,這種異常都發(fā)生在編譯階段,Java 編譯器會強 制程序去捕獲此類異常,即會出現(xiàn)要求你把這段可能出現(xiàn)異常的程序進行 try catch,該類異常一 般包括幾個方面:
1. 試圖在文件尾部讀取數(shù)據(jù)
2. 試圖打開一個錯誤格式的 URL
3. 試圖根據(jù)給定的字符串查找 class 對象,而這個字符串表示的類并不存在
異常的處理方式
遇到問題不進行具體處理,而是繼續(xù)拋給調(diào)用者 ( throw,throws )
拋出異常有三種形式,一是 throw,一個 throws,還有一種系統(tǒng)自動拋異常 。
public static void main(String[] args) {
String s = "abc";
if(s.equals("abc")) {
throw new NumberFormatException();
} else {
System.out.println(s);
}
}
int div(int a,int b) throws Exception {
return a/b;}
try catch 捕獲異常針對性處理方式
Throw 和 throws 的區(qū)別:
位置不同
1. throws 用在函數(shù)上 ,后面跟的是異常類,可以跟多個; 而 throw 用在函數(shù)內(nèi) ,后面跟的 是異常對象。
功能不同:
2. throws 用來聲明異常,讓調(diào)用者只知道該功能可能出現(xiàn)的問題 ,可以給出預先的處理方 式; throw 拋出具體的問題對象,執(zhí)行到 throw,功能就已經(jīng)結束了 ,跳轉到調(diào)用者,并 將具體的問題對象拋給調(diào)用者。也就是說 throw 語句獨立存在時,下面不要定義其他語 句,因為執(zhí)行不到。
3. throws 表示出現(xiàn)異常的一種可能性 ,并不一定會發(fā)生這些異常; throw 則是拋出了異常 , 執(zhí)行 throw 則一定拋出了某種異常對象。 13/04/2018 Page 103 of 283
4. 兩者都是消極處理異常的方式,只是拋出或者可能拋出異常,但是不會由函數(shù)去處理異 常,真正的處理異常由函數(shù)的上層調(diào)用處理
JAVA 反射
動態(tài)語言
動態(tài)語言,是指程序在運行時可以改變其結構:新的函數(shù)可以引進,已有的函數(shù)可以被刪除等結 構上的變化。比如常見的 JavaScript 就是動態(tài)語言,除此之外 Ruby,Python 等也屬于動態(tài)語言, 而 C、C++則不屬于動態(tài)語言。從反射角度說 JAVA 屬于半動態(tài)語言。
反射機制概念 (運行狀態(tài)中知道類所有的屬性和方法)

在 Java 中的反射機制是指 在運行狀態(tài)中,對于任意一個類都能夠知道這個類所有的屬性和方法; 并且對于任意一個對象,都能夠調(diào)用它的任意一個方法 ;這種動態(tài)獲取信息以及動態(tài)調(diào)用對象方 法的功能成為 Java 語言的反射機制。
反射的應用場合
編譯時類型和運行時類型
在 Java 程序中許多對象在運行是都會出現(xiàn)兩種類型:編譯時類型和運行時類型。 編譯時的類型由 聲明對象時實用的類型來決定,運行時的類型由實際賦值給對象的類型決定 。如: Person p=new Student();
其中編譯時類型為 Person,運行時類型為 Student 。 13/04/2018
Page 104 of 283
的編譯時類型無法獲取具體方法
程序在運行時還可能接收到外部傳入的對象, 該對象的編譯時類型為 Object ,但是程序有需要調(diào)用 該對象的運行時類型的方法。為了解決這些問題, 程序需要在運行時發(fā)現(xiàn)對象和類的真實信息 。 然而,如果編譯時根本無法預知該對象和類屬于哪些類,程序只能依靠運行時信息來發(fā)現(xiàn)該對象 和類的真實信息,此時就必須使用到反射了。
Java 反射 API
反射 API 用來生成 JVM 中的類、接口或則對象的信息。
1. Class 類:反射的核心類,可以獲取類的屬性,方法等信息。
2. Field 類:Java.lang.reflec 包中的類,表示類的成員變量,可以用來獲取和設置類之中的屬性 值。
3. Method 類: Java.lang.reflec 包中的類,表示類的方法,它可以用來獲取類中的方法信息或 者執(zhí)行方法。
4. Constructor 類: Java.lang.reflec 包中的類,表示類的構造方法。
反射使用步驟(獲取 Class 對象、調(diào)用對象方法)
1. 獲取想要操作的類的 Class 對象,他是反射的核心,通過 Class 對象我們可以任意調(diào)用類的方 法。
2. 調(diào)用 Class 類中的方法,既就是反射的使用階段。
3. 使用反射 API 來操作這些信息。
獲取 Class 對象的 3 種方法
調(diào)用某個對象的 getClass() 方法
Person p=new Person();
Class clazz=p.getClass();
調(diào)用某個類的 class 屬性來獲取該類對應的 Class 對象
Class clazz=Person.class;
使用 Class 類中的 forName() 靜態(tài)方法 ( 最安全 / 性能最好 )
Class clazz=Class.forName("類的全路徑"); (最常用)
當我們獲得了想要操作的類的 Class 對象后,可以通過 Class 類中的方法獲取并查看該類中的方法和屬性。
//獲取 Person 類的 Class 對象
Class clazz=Class.forName("reflection.Person"); 13/04/2018
Page 105 of 283
//獲取 Person 類的所有方法信息
Method[] method=clazz.getDeclaredMethods();
for(Method m:method){
System.out.println(m.toString()); }
//獲取 Person 類的所有成員屬性信息
Field[] field=clazz.getDeclaredFields();
for(Field f:field){
System.out.println(f.toString()); }
//獲取 Person 類的所有構造方法信息
Constructor[] constructor=clazz.getDeclaredConstructors();
for(Constructor c:constructor){
System.out.println(c.toString()); }
創(chuàng)建對象的兩種方法
Class 對象的 newInstance()
1. 使用 Class 對象的 newInstance()方法來創(chuàng)建該 Class 對象對應類的實例,但是這種方法要求 該 Class 對象對應的類有默認的空構造器。
調(diào)用 Constructor 對象的 newInstance()
2. 先使用 Class 對象獲取指定的 Constructor 對象,再調(diào)用 Constructor 對象的 newInstance() 方法來創(chuàng)建 Class 對象對應類的實例,通過這種方法可以選定構造方法創(chuàng)建實例。
//獲取 Person 類的 Class 對象
Class clazz=Class.forName("reflection.Person");
//使用.newInstane 方法創(chuàng)建對象
Person p=(Person) clazz.newInstance();
//獲取構造方法并創(chuàng)建對象
Constructor c=clazz.getDeclaredConstructor(String.class,String.class,int.class);
//創(chuàng)建對象并設置屬性 13/04/2018
Page106 of 283
Person p1=(Person) c.newInstance("李四","男",20);
總結
本篇文章就到這里了,希望能給你帶來幫助,也希望您能夠多多關注腳本之家的更多內(nèi)容!
相關文章
SpringBoot+RabbitMQ實現(xiàn)消息可靠傳輸詳解
消息的可靠傳輸是面試必問的問題之一,保證消息的可靠傳輸主要在生產(chǎn)端開啟?comfirm?模式,RabbitMQ?開啟持久化,消費端關閉自動?ack?模式。本文將詳解SpringBoot整合RabbitMQ如何實現(xiàn)消息可靠傳輸,需要的可以參考一下2022-05-05
springboot+hutool批量生成二維碼壓縮導出功能
這篇文章主要介紹了springboot+hutool批量生成二維碼壓縮導出功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-10-10
SpringBoot基于Redis實現(xiàn)短信登錄的操作
驗證碼登錄是非常常見的一種登錄方式,能夠簡化用戶登錄的過程,本文主要介紹了SpringBoot基于Redis實現(xiàn)短信登錄的操作,具有一定的參考價值,感興趣的可以了解一下2023-12-12
Java中ShardingSphere分庫分表實戰(zhàn)
我們做項目的時候,數(shù)據(jù)量比較大,單表千萬級別的,需要分庫分表,本文主要介紹了Java中ShardingSphere分庫分表實戰(zhàn),感興趣的可以了解一下2021-09-09
圖解Java經(jīng)典算法冒泡選擇插入希爾排序的原理與實現(xiàn)
冒泡排序是一種簡單的排序算法,它也是一種穩(wěn)定排序算法。其實現(xiàn)原理是重復掃描待排序序列,并比較每一對相鄰的元素,當該對元素順序不正確時進行交換。一直重復這個過程,直到?jīng)]有任何兩個相鄰元素可以交換,就表明完成了排序2022-09-09

