java.lang.reflect(javalangreflectinvocation null)

本文目錄一覽:

java.lang中的Class類,與java.lang.reflect包中的construct、method等有什麼聯繫和區別?

有一些聯繫,談不上區別。他們是獨立的類,各自有自己的功能。

你每定義一個類(產生一個java文件)

系統運行的時候,加載java文件 系統就多了一個類的定義

系統裏面保存類的定義的方式是就是用java.lang.Class

也就是說 任何類都有一個對應的Class對象,

Class clz = String.class ; class靜態字段就是該類的Class對象。

通過Class對象,可以得到construct,method這些具體的類定義的細節。

類的細節就是構造函數,普通函數,靜態函數,字段成員等等,就對應了java.lang.reflect下面的那一堆。

java.lang.reflect.InvocationTargetException這個異常什麼意思

InvocationTargetException異常由Method.invoke(obj, args…)方法拋出。當被調用的方法的內部拋出了異常而沒有被捕獲時,將由此異常接收。

至於具體原因,就要看代碼和詳細的錯誤信息了。

Java中的Class類與java.lang.reflect間的關係

Class類是java.lang包下的類,針對你的提問, 舉一個簡單易懂的例子來理解一下:package com.test;public class Student { //聲明私用屬性

private int id;

private String username;

private String userpwd;

private int age;

//共有屬性

public String str = “some strings”; //私用方法

private Student getStudent(){

return new Student();

}

//共有的setter和getter方法

public int getId() {

return id;

} public void setId(int id) {

this.id = id;

} public String getUsername() {

return username;

} public void setUsername(String username) {

this.username = username;

} public String getUserpwd() {

return userpwd;

} public void setUserpwd(String userpwd) {

this.userpwd = userpwd;

} public int getAge() {

return age;

} public void setAge(int age) {

this.age = age;

} public String getStr() {

return str;

} public void setStr(String str) {

this.str = str;

}

}

———————————————————————————— package com.test;import java.lang.reflect.Method;public class ClassTest { public static void main(String[] args) {

//獲取class對象的方式一

Student stu = new Student();

Class class1 = stu.getClass();

/*

* 返回一個包含某些 Method 對象的數組,

* 這些對象反映此 Class 對象所表示的類或接口(

* 包括那些由該類或接口聲明的以及

* 從超類和超接口繼承的那些的類或接口)的公共 member 方法。

*/

Method[] method = class1.getMethods(); //method[]數組存放的是Method對象

int length = method.length;

for(int i=0; ilength; i++){

System.out.println(method[i].getName()); //method[i]就是一個Method對象

}

/*

* 你要明白class1對象的來源是Student,那麼返回的構造函數,方法,屬性等信息就和這個類有關

* 其他構造函數,屬性的反射就舉例子了, 道理是一樣的.

*/

//獲取class對象的方式二

Class class2 = Student.class;

//獲取class對象的方式三

Class class3 = Integer.TYPE;

}

}

為什麼會產生java.lang.reflect.invocationtargetexception

InvocationTargetException 是一種包裝由調用方法或構造方法所拋出異常的受查異常。這個異常並不是Eclipse插件開發特有的,而是標準JDK中的,它定義在 java.lang.reflect包下。在進行Java開發的時候很少會接觸到這個異常,不過在進行Eclipse插件開發中則不同,很多API都聲明拋出此類異常,因此必須對此異常進行處理。

例如,我們開發一個方法用來統一處理異常:

private static void handleException(Exception e)

{

MessageDialog.openError(Activator.getDefault().getWorkbench()

.getDisplay().getActiveShell(), “error”, e.getMessage());

e.printStackTrace();

}

我們發現當傳遞來的參數e為InvocationTargetException 的時候彈出的對話框中的消息是空的,查看InvocationTargetException 的源碼得知InvocationTargetException 並沒有覆蓋getMessage方法,所以消息當然是空的了。我們需要調用InvocationTargetException 的getTargetException方法得到要被包裝的異常,這個異常才是真正我們需要的異常。修改代碼如下所示:

private static void handleException(Exception e)

{

String msg = null;

if (e instanceof InvocationTargetException)

{

Throwable targetEx = ((InvocationTargetException) e)

.getTargetException();

if (targetEx != null)

{

msg = targetEx.getMessage();

}

} else

{

msg = e.getMessage();

}

MessageDialog.openError(Activator.getDefault().getWorkbench()

.getDisplay().getActiveShell(), “error”, msg);

e.printStackTrace();

}

java.lang.reflect.invocationtargetexception和數據庫表空間有沒有關係

和數據庫表空間沒有關係

InvocationTargetException異常由Method.invoke(obj, args…)方法拋出。當被調用的方法的內部拋出了異常而沒有被捕獲時,將由此異常接收。

示例:

[java] view plain copy print?

package com.zzj.test.reflect;

public class Reflect {

public void run(int i) throws ZeroException {

B b = new B();

b.run(i);

}

}

class B {

public void run(int i) throws ZeroException {

if (i 0) {

throw new ZeroException(“參數不能小於零!”);

}

System.out.println(“參數:” + i);

}

}

class ZeroException extends Exception {

private static final long serialVersionUID = 1L;

private String detailMessage;

public ZeroException(String detailMessage) {

this.detailMessage = detailMessage;

}

public String getMessage() {

return detailMessage;

}

}

測試:

[java] view plain copy print?

package com.zzj.test.reflect;

import java.lang.reflect.InvocationTargetException;

import java.lang.reflect.Method;

public class Test {

public static void main(String[] args) {

try {

Class? clazz = Class.forName(“com.zzj.test.reflect.Reflect”);

Method method = clazz.getMethod(“run”, int.class);

method.invoke(clazz.newInstance(), -1);

} catch (ClassNotFoundException e) {

e.printStackTrace();

} catch (SecurityException e) {

e.printStackTrace();

} catch (NoSuchMethodException e) {

e.printStackTrace();

} catch (IllegalArgumentException e) {

e.printStackTrace();

} catch (IllegalAccessException e) {

e.printStackTrace();

} catch (InvocationTargetException e) {

System.out.println(“此處接收被調用方法內部未被捕獲的異常”);

e.printStackTrace();

} catch (InstantiationException e) {

e.printStackTrace();

}

}

}

輸出:

[plain] view plain copy print?

此處接收被調用方法內部未被捕獲的異常

java.lang.reflect.InvocationTargetException

at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)

at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)

at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)

at java.lang.reflect.Method.invoke(Unknown Source)

at com.zzj.test.reflect.Test.main(Test.java:11)

Caused by: com.zzj.test.reflect.ZeroException: 參數不能小於零!

at com.zzj.test.reflect.B.run(Reflect.java:13)

at com.zzj.test.reflect.Reflect.run(Reflect.java:6)

… 5 more

也可以直接打印目標異常:

[java] view plain copy print?

package com.zzj.test.reflect;

import java.lang.reflect.InvocationTargetException;

import java.lang.reflect.Method;

public class Test {

public static void main(String[] args) {

try {

Class? clazz = Class.forName(“com.zzj.test.reflect.Reflect”);

Method method = clazz.getMethod(“run”, int.class);

method.invoke(clazz.newInstance(), -1);

} catch (ClassNotFoundException e) {

e.printStackTrace();

} catch (SecurityException e) {

e.printStackTrace();

} catch (NoSuchMethodException e) {

e.printStackTrace();

} catch (IllegalArgumentException e) {

e.printStackTrace();

} catch (IllegalAccessException e) {

e.printStackTrace();

} catch (InvocationTargetException e) {

System.out.println(“此處接收被調用方法內部未被捕獲的異常”);

Throwable t = e.getTargetException();// 獲取目標異常

t.printStackTrace();

} catch (InstantiationException e) {

e.printStackTrace();

}

}

}

輸出:

[plain] view plain copy print?

此處接收被調用方法內部未被捕獲的異常

com.zzj.test.reflect.ZeroException: 參數不能小於零!

at com.zzj.test.reflect.B.run(Reflect.java:13)

at com.zzj.test.reflect.Reflect.run(Reflect.java:6)

at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)

at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)

at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)

at java.lang.reflect.Method.invoke(Unknown Source)

at com.zzj.test.reflect.Test.main(Test.java:11)

java反射機制出錯java.lang.reflect.InvocationTargetException

action.ManagerAction.login(ManagerAction.java:58) 這個地方發生空指針異常了,就是這個地方取值是null了

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/249781.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-12 17:13
下一篇 2024-12-12 17:13

相關推薦

  • Java JsonPath 效率優化指南

    本篇文章將深入探討Java JsonPath的效率問題,並提供一些優化方案。 一、JsonPath 簡介 JsonPath是一個可用於從JSON數據中獲取信息的庫。它提供了一種DS…

    編程 2025-04-29
  • java client.getacsresponse 編譯報錯解決方法

    java client.getacsresponse 編譯報錯是Java編程過程中常見的錯誤,常見的原因是代碼的語法錯誤、類庫依賴問題和編譯環境的配置問題。下面將從多個方面進行分析…

    編程 2025-04-29
  • Java騰訊雲音視頻對接

    本文旨在從多個方面詳細闡述Java騰訊雲音視頻對接,提供完整的代碼示例。 一、騰訊雲音視頻介紹 騰訊雲音視頻服務(Cloud Tencent Real-Time Communica…

    編程 2025-04-29
  • Java Bean加載過程

    Java Bean加載過程涉及到類加載器、反射機制和Java虛擬機的執行過程。在本文中,將從這三個方面詳細闡述Java Bean加載的過程。 一、類加載器 類加載器是Java虛擬機…

    編程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介紹

    本文將詳細介紹Java Milvus SearchParam withoutFields的相關知識和用法。 一、什麼是Java Milvus SearchParam without…

    編程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java語言中的一個版本,於2014年3月18日發佈。本文將從多個方面對Java 8中某一周的周一進行詳細的闡述。 一、數組處理 Java 8新特性之一是Stream…

    編程 2025-04-29
  • Java判斷字符串是否存在多個

    本文將從以下幾個方面詳細闡述如何使用Java判斷一個字符串中是否存在多個指定字符: 一、字符串遍歷 字符串是Java編程中非常重要的一種數據類型。要判斷字符串中是否存在多個指定字符…

    編程 2025-04-29
  • VSCode為什麼無法運行Java

    解答:VSCode無法運行Java是因為默認情況下,VSCode並沒有集成Java運行環境,需要手動添加Java運行環境或安裝相關插件才能實現Java代碼的編寫、調試和運行。 一、…

    編程 2025-04-29
  • Java任務下發回滾系統的設計與實現

    本文將介紹一個Java任務下發回滾系統的設計與實現。該系統可以用於執行複雜的任務,包括可回滾的任務,及時恢復任務失敗前的狀態。系統使用Java語言進行開發,可以支持多種類型的任務。…

    編程 2025-04-29
  • Java 8 Group By 會影響排序嗎?

    是的,Java 8中的Group By會對排序產生影響。本文將從多個方面探討Group By對排序的影響。 一、Group By的概述 Group By是SQL中的一種常見操作,它…

    編程 2025-04-29

發表回復

登錄後才能評論