Java lang reflect invocationtargetexception ошибка причина

The java.lang.reflect.InvocationTargetException occurs while working with the reflection API. Explore the reasons behind this exception and how to handle it.

Overview

Exception Handling is one of the most powerful mechanisms in Java. It is used to handle the runtime errors during execution so that in case of an error, you can prevent the program from crashing and the flow of the application can remain uninterrupted despite the error.

If you have ever worked with Java Reflection API, you must have at least once encountered the java.lang.reflect.InvocationTargetException in your program. In this article, we will be understanding the InvocationTargetException, the reasons behind its occurrence, and how to properly handle it. The article also includes some appropriate examples for your ease.

explore new Java roles

What is Java reflection?

Just for starters, Reflection is a feature in Java that allows a Java program to examine itself and manipulate the internal properties of the program during execution.

For instance, it is allowed for a Java class to obtain the names of all its members and display them while executing.

This feature to examine and manipulate a Java class from within itself may not seem to be a big thing and feels like a common feature, but surprisingly this feature does not exist in various renowned programming languages nor there is any alternative for it.

For instance, Cor C++ programmers have no possible way to obtain information about the functions defined within their program.

Java reflection offers some very significant uses, especially in JavaBeans, where software components can be tweaked visually using a builder tool.

The tool makes use of reflection to obtain the properties of the Java class when they are dynamically loaded.

See this code below demonstrating a simple example of using reflection

1.  import java.lang.reflect.*;
2. 
3.    public class DumpMethods {
4.      public static void main(String args[])
5.    {
6.      try {
7.         Class myClass = Class.forName(args[0]);
8.         Method m[] = myClass.getDeclaredMethods();
9.         for (int i = 0; i < m.length; i++)
10.        System.out.println(m[i].toString());
11.   }
12.     catch (Throwable e) {
13.     System.err.println(e);
14.      }
15.    }
16. }

 This code snipped is for the invocation of:

java DumpMethods java.util.Stack

And the output is:

public java.lang.Object java.util.Stack.push(
    java.lang.Object)
   public synchronized
     java.lang.Object java.util.Stack.pop()
   public synchronized
      java.lang.Object java.util.Stack.peek()
   public boolean java.util.Stack.empty()
   public synchronized
     int java.util.Stack.search(java.lang.Object)

The output list down the names of all methods of class java.util.Stack, along with their fully qualified parameter and return types.

The InvocationTargetException is not the actual exception we have to deal with instead it is a checked exception that wraps the actual exception thrown by an invoked method or constructor. As of the release of JDK 2.4, this exception has been modified enough to be used as a  general-purpose exception-chaining mechanism.

There have been some changes since the beginning as the “target exception” that is provided at the time of construction and is accessed through the getTargetException() method is now known as the cause method, and can be accessed via the Throwable.getCause() method, but the previously mentioned legacy method is also still applicable.

See this example of a java.lang.reflect.InvocationTargetException thrown when a method that is called using Method.invoke() throws an exception:

1. import java.lang.reflect.InvocationTargetException;
2. import java.lang.reflect.Method;
3. 
4. public class InvocationTargetExceptionDemo {
5.    public int dividedByZero() {
6.         return 1 / 0;
7.     }
8. 
9.     public static void main(String[] args) throws NoSuchMethodException, 
       IllegalAccessException {
10.       InvocationTargetExceptionDemo invoked = new InvocationTargetExceptionDemo(); 
11.       Method method = InvocationTargetExceptionDemo.class.getMethod("divisionByZero");
12.      try {
13.      method.invoke(invoked);
14.     } catch (InvocationTargetException e) {
15.       e.printStackTrace();
16.    }
17.    }
18.  }

In this example, the main() method invokes the dividedByZero() method using Method.invoke(). As dividedByZero() method will throw an ArithmeticException, it will be wrapped within an InvocationTargetException thrown in the main() method.

The output error is as shown:

java.lang.reflect.InvocationTargetException
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.base/java.lang.reflect.Method.invoke(Method.java:564)
    at InvocationTargetExceptionDemo.main(InvocationTargetExceptionDemo.java:13)
Caused by: java.lang.ArithmeticException: / by zero
    at InvocationTargetExceptionDemo.dividedByZero(InvocationTargetExceptionDemo.java:6)
    ... 5 more

As discussed earlier, the above mentioned code snippet along with its output has made it clear that the actual exception is the ArithmeticException and it got wrapped into an InvocationTargetException.

Now, the question that must come to your mind is why the reflection does not directly throw the actual exception instead of wrapping it into an InvocationTargetException? Why do we even need it? The reason is clear. It allows the programmer to first understand whether the exception has occurred due to some sort of failure in properly calling the method through the reflection layer or whether the exception has occurred within the method itself.

What causes java.lang.reflect.InvocationTargetException?

The java.lang.reflect.InvocationTargetException mainly occurs while working with the reflection layer. When you attempt to invoke a method or constructor and it throws an underlying exception, that underlying exception is the actual cause of the occurrence of java.lang.reflect.InvocationTargetException. The reflection layer wraps the actual exception thrown by the method with the InvocationTargetException thus you get the java.lang.reflect.InvocationTargetException in return.

How to handle with java.lang.reflect.InvocationTargetException?

To properly deal with the InvocationTargetException, you have to handle the actual underlying exception that is the main reason for InvocationTargetException. To cater to that, the Throwable.getCause() method is used to get more information about the exception such as the type of exception, after invocation. This information is undoubtedly very useful for resolving the java.lang.reflect.InvocationTargetException.

Consider the below example, it is an extension to the previous code example which intentionally generated an exception (divided by zero) in the method InvocationTargetExceptionDemo:

1. import java.lang.reflect.Method; 
2. public class TestInvocationException { 
3.      public static void main(String[] args) { 
4.       InvocationDemo id = new InvocationDemo(); 
5.        ¬¬¬¬¬¬// Getting Access to all the methods of myInvocation Class: 
6.    Method[] m = InvocationDemo.class.getMethods(); 
7.   try { 
8.   // First method of the myInvocatio Class is invoked here 
9.   m[0].invoke(id); 
10.     } 
11.    catch(Exception e) { 
12.      // wrapper exception: 
13.     System.out.println("Wrapper exception: " + e); 
14.     // getCause method is used with the actual exception: 
15.      System.out.println("Underlying exception: " + e.getCause()); 
16.    } 
17.   } 
18.  } 
19. 
20.    class myInvocation{ 
21.      public void InvocationTargetExceptionDemo() { 
22.        // Dividing by zero again 
23.        System.out.println(3 / 0); 
24.     } 
25. }

Output generated from the getCause() method is shown below, it clearly states the type of underlying exception:

Wrapper exception: java.lang.reflect.InvocationTargetException

Underlying exception: java.lang.ArithmeticException: / by zero

Here, the getCause() method is used with the same exception object that was thrown and it is identified  that ArithmeticException.class is the cause of the InvocationTargetException.

Now, it may seem very easy as programmers can easily identify the divided by zero error from the code and exception for it may be already known but suppose you are dealing with any other exception and your code is significantly longer and more complex, just the name of the exception from the getCause() method can come in very handy.

Also Read: How to use Java Generic Interface

So, once you get the reason behind the underlying exception, you can also re-throw the same exception, you can also wrap it in some custom exception, or you can also log the exception based on your requirement.

Conclusion

Exceptions are the best way to deal with errors in any programming language. Proper knowledge of exceptions and their dealing can be a lifesaver for a Java coder on many occasions.

In this comprehensive article, we have explored the java.lang.reflect.invocationtargetException.

We discussed how the reflection layer wraps an underlying exception in Java. To be precise, when we invoke a class using the Method.invoke(), and if it throws an exception; it will be wrapped by the java.lang.reflect.InvocationTargetException class.­ We have also seen how to determine the underlying reason behind the occurrence of InvocationTargetException and how to handle such a problem in your Java code.

new Java jobs

Содержание

  1. Invocation Target Exception Class
  2. Definition
  3. Remarks
  4. Constructors
  5. Fields
  6. Properties
  7. Methods
  8. Explicit Interface Implementations
  9. Extension Methods
  10. Understanding java.lang.reflect.InvocationTargetException and why it occurs
  11. Reason for java.lang.reflect.InvocationTargetException
  12. Handle InvocationTargetException
  13. Was this post helpful?
  14. Share this
  15. Related Posts
  16. Author
  17. Related Posts
  18. [Fixed] Unsupported class file major version 61 in Java
  19. [Fixed] java.lang.ClassCastException: java.util.Arrays$ArrayList cannot be cast to java.util.ArrayList
  20. [Fixed] java.util.HashMap$Values cannot be cast to class java.util.List
  21. [Fixed] Unable to obtain LocalDateTime from TemporalAccessor
  22. Invocation Target Exception Класс
  23. Определение
  24. Комментарии
  25. Конструкторы
  26. Свойства
  27. Методы
  28. Явные реализации интерфейса
  29. Методы расширения

Invocation Target Exception Class

Definition

Some information relates to prerelease product that may be substantially modified before it’s released. Microsoft makes no warranties, express or implied, with respect to the information provided here.

InvocationTargetException is a checked exception that wraps an exception thrown by an invoked method or constructor.

Portions of this page are modifications based on work created andВ shared by the Android Open Source Project and used according to terms described in the Creative Commons 2.5 Attribution License.

Constructors

Constructs an InvocationTargetException with null as the target exception.

A constructor used when creating managed representations of JNI objects; called by the runtime.

Constructs a InvocationTargetException with a target exception.

Constructs a InvocationTargetException with a target exception and a detail message.

Fields

Properties

Returns the cause of this throwable or null if the cause is nonexistent or unknown.

(Inherited from Throwable) Class (Inherited from Throwable) Clause Handle

The handle to the underlying Android instance.

(Inherited from Throwable) JniIdentityHashCode (Inherited from Throwable) JniPeerMembers LocalizedMessage

Creates a localized description of this throwable.

(Inherited from Throwable) Message

Returns the detail message string of this throwable.

(Inherited from Throwable) PeerReference (Inherited from Throwable) StackTrace (Inherited from Throwable) TargetException

Get the thrown target exception.

This API supports the Mono for Android infrastructure and is not intended to be used directly from your code.

This API supports the Mono for Android infrastructure and is not intended to be used directly from your code.

Methods

Appends the specified exception to the exceptions that were suppressed in order to deliver this exception.

(Inherited from Throwable) Dispose() (Inherited from Throwable) Dispose(Boolean) (Inherited from Throwable) FillInStackTrace()

Fills in the execution stack trace.

(Inherited from Throwable) GetStackTrace()

Provides programmatic access to the stack trace information printed by #printStackTrace() .

(Inherited from Throwable) GetSuppressed()

Returns an array containing all of the exceptions that were suppressed, typically by the try -with-resources statement, in order to deliver this exception.

(Inherited from Throwable) InitCause(Throwable)

Initializes the cause of this throwable to the specified value.

(Inherited from Throwable) PrintStackTrace()

Prints this throwable and its backtrace to the standard error stream.

(Inherited from Throwable) PrintStackTrace(PrintStream)

Prints this throwable and its backtrace to the specified print stream.

(Inherited from Throwable) PrintStackTrace(PrintWriter)

Prints this throwable and its backtrace to the specified print writer.

(Inherited from Throwable) SetHandle(IntPtr, JniHandleOwnership)

Sets the Handle property.

(Inherited from Throwable) SetStackTrace(StackTraceElement[])

Sets the stack trace elements that will be returned by #getStackTrace() and printed by #printStackTrace() and related methods.

(Inherited from Throwable) ToString() (Inherited from Throwable) UnregisterFromRuntime() (Inherited from Throwable)

Explicit Interface Implementations

IJavaPeerable.Disposed() (Inherited from Throwable)
IJavaPeerable.DisposeUnlessReferenced() (Inherited from Throwable)
IJavaPeerable.Finalized() (Inherited from Throwable)
IJavaPeerable.JniManagedPeerState (Inherited from Throwable)
IJavaPeerable.SetJniIdentityHashCode(Int32) (Inherited from Throwable)
IJavaPeerable.SetJniManagedPeerState(JniManagedPeerStates) (Inherited from Throwable)
IJavaPeerable.SetPeerReference(JniObjectReference) (Inherited from Throwable)

Extension Methods

Performs an Android runtime-checked type conversion.

Источник

Understanding java.lang.reflect.InvocationTargetException and why it occurs

In this post, we will see about java.lang.reflect.InvocationTargetException .

You might get java.lang.reflect.InvocationTargetException while working with reflection in java.

Reason for java.lang.reflect.InvocationTargetException

Reflection layer throws this exception when calling method or constructor throws any exception. java.lang.reflect.InvocationTargetException wraps underlying exception thrown by actual method or constructor call.

Let’s see this with the help of example:
Create a simple class named StringUtils.java . It will have method getLengthOfString() which does not have null handling, so when we pass null to this method, it will throw java.lang.NullPointerException.

Create anther class to call getLengthOfString using reflection.

Output:

As you can see, we are getting java.lang.reflect.InvocationTargetException exception because of underlying NullPointerException.

Reflection layer wraps java.lang.reflect.InvocationTargetException around actual Exception to demostrate that this exception was raised during reflection API call.

Handle InvocationTargetException

As underlying exception is actual cause of InvocationTargetException, we can use Throwable’s getCause() method to get actual underlyting exception and use it to log or rethrow the exception.

To resolve InvocationTargetException , you need to solve underlying Exception(NullPointerException) in above example.
Let’s handle the null check in StringUtils.java class and you won’t get any exception anymore.

Now when we run ReflectionMain.java again, you will see below output:

That’s all about java.lang.reflect.InvocationTargetException in java.

Was this post helpful?

[Fixed] no suitable driver found for jdbc

Cannot find symbol Java

[Fixed] Unsupported class file major version 61 in Java

Table of ContentsReason for Unsupported class file major version 61 in JavaSolution for Unsupported class file major version 61 in JavaAndorid studio/Intellij Idea with gradleAny other scenario In this post, we will see how to fix Unsupported class file major version 61 in Java. Reason for Unsupported class file major version 61 in Java You […]

[Fixed] java.lang.ClassCastException: java.util.Arrays$ArrayList cannot be cast to java.util.ArrayList

Table of ContentsReason for java.lang.ClassCastException: java.util.Arrays$ArrayList cannot be cast to java.util.ArrayListFixes for java.lang.ClassCastException: java.util.Arrays$ArrayList cannot be cast to java.util.ArrayListUse ArrayList’s constructorAssign Arrays.asList() to List reference rather than ArrayList In this post, we will see how to fix java.lang.ClassCastException: java.util.Arrays$ArrayList cannot be cast to java.util.ArrayList. ClassCastException is runtime exception which indicate that code has tried to […]

[Fixed] java.util.HashMap$Values cannot be cast to class java.util.List

Table of ContentsWhy HashMap values cannot be cast to list?Fix for java.util.HashMap$Values cannot be cast to class java.util.List In this post, we will see how to fix error java.util.HashMap$Values cannot be cast to class java.util.List. Why HashMap values cannot be cast to list? HashMap values returns java.util.Collection and you can not cast Collection to List […]

[Fixed] Unable to obtain LocalDateTime from TemporalAccessor

Table of ContentsUnable to obtain LocalDateTime from TemporalAccessor : ReasonUnable to obtain LocalDateTime from TemporalAccessor : FixLocalDate’s parse() method with atStartOfDay()Use LocalDate instead of LocalDateTime In this article, we will see how to fix Unable to obtain LocalDateTime from TemporalAccessor in Java 8. Unable to obtain LocalDateTime from TemporalAccessor : Reason You will generally get […]

Источник

Invocation Target Exception Класс

Определение

Некоторые сведения относятся к предварительной версии продукта, в которую до выпуска могут быть внесены существенные изменения. Майкрософт не предоставляет никаких гарантий, явных или подразумеваемых, относительно приведенных здесь сведений.

InvocationTargetException — это проверенное исключение, которое заключает в оболочку исключение, создаваемое вызванным методом или конструктором.

Комментарии

Части этой страницы являются изменениями, основанными на работе, созданной и совместно используемой проектом Android и используемой в соответствии с условиями, Creative Commons 2.5 Attribution License.

Конструкторы

Создает с в InvocationTargetException null качестве целевого исключения.

Конструктор, используемый при создании управляемых представлений объектов JNI; вызывается средой выполнения.

Создает исключение InvocationTargetException с целевым исключением.

Создает исключение InvocationTargetException с целевым исключением и подробным сообщением.

InvocationTargetException — это проверенное исключение, которое заключает в оболочку исключение, создаваемое вызванным методом или конструктором.

(Унаследовано от Throwable)

Свойства

Возвращает причину этого вызываемого объекта или null значение , если причина не существует или неизвестна.

(Унаследовано от Throwable) Class

InvocationTargetException — это проверенное исключение, которое заключает в оболочку исключение, создаваемое вызванным методом или конструктором.

(Унаследовано от Throwable) Clause

InvocationTargetException — это проверенное исключение, которое заключает в оболочку исключение, создаваемое вызванным методом или конструктором.

Дескриптор базового экземпляра Android.

(Унаследовано от Throwable) JniIdentityHashCode

InvocationTargetException — это проверенное исключение, которое заключает в оболочку исключение, создаваемое вызванным методом или конструктором.

(Унаследовано от Throwable) JniPeerMembers

InvocationTargetException — это проверенное исключение, которое заключает в оболочку исключение, создаваемое вызванным методом или конструктором.

Создает локализованное описание этого вызываемого объекта.

(Унаследовано от Throwable) Message

Возвращает строку подробного сообщения этого вызываемого объекта.

(Унаследовано от Throwable) PeerReference

InvocationTargetException — это проверенное исключение, которое заключает в оболочку исключение, создаваемое вызванным методом или конструктором.

(Унаследовано от Throwable) StackTrace

InvocationTargetException — это проверенное исключение, которое заключает в оболочку исключение, создаваемое вызванным методом или конструктором.

(Унаследовано от Throwable) TargetException

Получение созданного целевого исключения.

Этот API поддерживает инфраструктуру Mono для Android и не предназначен для использования непосредственно из кода.

Этот API поддерживает инфраструктуру Mono для Android и не предназначен для использования непосредственно из кода.

Методы

Добавляет указанное исключение к исключениям, которые были подавлены для доставки этого исключения.

(Унаследовано от Throwable) Dispose()

InvocationTargetException — это проверенное исключение, которое заключает в оболочку исключение, создаваемое вызванным методом или конструктором.

(Унаследовано от Throwable) Dispose(Boolean)

InvocationTargetException — это проверенное исключение, которое заключает в оболочку исключение, создаваемое вызванным методом или конструктором.

(Унаследовано от Throwable) FillInStackTrace()

Заполняет трассировку стека выполнения.

(Унаследовано от Throwable) GetStackTrace()

Предоставляет программный доступ к сведениям трассировки стека, напечатанным . #printStackTrace()

(Унаследовано от Throwable) GetSuppressed()

Возвращает массив, содержащий все исключения, которые были подавлены, как правило, инструкцией try -with-resources, для доставки этого исключения.

(Унаследовано от Throwable) InitCause(Throwable)

Инициализирует причину этого вызываемого объекта указанным значением.

(Унаследовано от Throwable) PrintStackTrace()

Выводит этот вызываемый объект и его обратную передачу в стандартный поток ошибок.

(Унаследовано от Throwable) PrintStackTrace(PrintStream)

Выводит этот бросаемый объект и его обратную передачу в указанный поток печати.

(Унаследовано от Throwable) PrintStackTrace(PrintWriter)

Выводит этот бросаемый объект и его обратную сторону в указанный модуль записи печати.

(Унаследовано от Throwable) SetHandle(IntPtr, JniHandleOwnership)

(Унаследовано от Throwable) SetStackTrace(StackTraceElement[])

Задает элементы трассировки стека, которые будут возвращены #getStackTrace() и напечатаны связанными методами #printStackTrace() и .

(Унаследовано от Throwable) ToString()

InvocationTargetException — это проверенное исключение, которое заключает в оболочку исключение, создаваемое вызванным методом или конструктором.

(Унаследовано от Throwable) UnregisterFromRuntime()

InvocationTargetException — это проверенное исключение, которое заключает в оболочку исключение, создаваемое вызванным методом или конструктором.

(Унаследовано от Throwable)

Явные реализации интерфейса

InvocationTargetException — это проверенное исключение, которое заключает в оболочку исключение, создаваемое вызванным методом или конструктором.

(Унаследовано от Throwable) IJavaPeerable.DisposeUnlessReferenced()

InvocationTargetException — это проверенное исключение, которое заключает в оболочку исключение, создаваемое вызванным методом или конструктором.

(Унаследовано от Throwable) IJavaPeerable.Finalized()

InvocationTargetException — это проверенное исключение, которое заключает в оболочку исключение, создаваемое вызванным методом или конструктором.

(Унаследовано от Throwable) IJavaPeerable.JniManagedPeerState

InvocationTargetException — это проверенное исключение, которое заключает в оболочку исключение, создаваемое вызванным методом или конструктором.

(Унаследовано от Throwable) IJavaPeerable.SetJniIdentityHashCode(Int32)

InvocationTargetException — это проверенное исключение, которое заключает в оболочку исключение, создаваемое вызванным методом или конструктором.

(Унаследовано от Throwable) IJavaPeerable.SetJniManagedPeerState(JniManagedPeerStates)

InvocationTargetException — это проверенное исключение, которое заключает в оболочку исключение, создаваемое вызванным методом или конструктором.

(Унаследовано от Throwable) IJavaPeerable.SetPeerReference(JniObjectReference)

InvocationTargetException — это проверенное исключение, которое заключает в оболочку исключение, создаваемое вызванным методом или конструктором.

(Унаследовано от Throwable)

Методы расширения

Выполняет преобразование типа, проверенного средой выполнения Android.

InvocationTargetException — это проверенное исключение, которое заключает в оболочку исключение, создаваемое вызванным методом или конструктором.

InvocationTargetException — это проверенное исключение, которое заключает в оболочку исключение, создаваемое вызванным методом или конструктором.

Источник

In this post, we will see about java.lang.reflect.InvocationTargetException.

You might get java.lang.reflect.InvocationTargetException while working with reflection in java.

Reflection layer throws this exception when calling method or constructor throws any exception. java.lang.reflect.InvocationTargetException wraps underlying exception thrown by actual method or constructor call.

Let’s see this with the help of example:
Create a simple class named StringUtils.java. It will have method getLengthOfString() which does not have null handling, so when we pass null to this method, it will throw java.lang.NullPointerException.

package org.arpit.java2blog;

public class StringUtils {

    public int getLengthOfString(String str)

    {

        return str.length();

    }

}

Create anther class to call getLengthOfString using reflection.

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

package org.arpit.java2blog;

import java.lang.reflect.InvocationTargetException;

import java.lang.reflect.Method;

public class ReflectionMain {

    public static void main(String[] args) {

        StringUtils su=new StringUtils();

        try {

            Class[] paramString = new Class[1];

            paramString[0] = String.class;

            Method method=StringUtils.class.getMethod(«getLengthOfString»,paramString);

            String str=null;

            Object len = method.invoke(su, str);

            System.out.println(len);

        } catch (NoSuchMethodException | SecurityException | IllegalAccessException | IllegalArgumentException | InvocationTargetException e) {

            e.printStackTrace();

        }

    }

}

Output:

java.lang.reflect.InvocationTargetException
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.base/java.lang.reflect.Method.invoke(Method.java:567)
at org.arpit.java2blog.ReflectionMain.main(ReflectionMain.java:16)
Caused by: java.lang.NullPointerException
at org.arpit.java2blog.StringUtils.getLengthOfString(StringUtils.java:7)
… 5 more

As you can see, we are getting java.lang.reflect.InvocationTargetException exception because of underlying NullPointerException.

Reflection layer wraps java.lang.reflect.InvocationTargetException around actual Exception to demostrate that this exception was raised during reflection API call.

Handle InvocationTargetException

As underlying exception is actual cause of InvocationTargetException, we can use Throwable's getCause() method to get actual underlyting exception and use it to log or rethrow the exception.

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

package org.arpit.java2blog;

import java.lang.reflect.InvocationTargetException;

import java.lang.reflect.Method;

public class ReflectionMain {

    public static void main(String[] args) {

        StringUtils su=new StringUtils();

        try {

            Class[] paramString = new Class[1];

            paramString[0] = String.class;

            Method method=StringUtils.class.getMethod(«getLengthOfString»,paramString);

            String str=null;

            Object len = method.invoke(su, str);

            System.out.println(len);

        } catch (NoSuchMethodException | SecurityException | IllegalAccessException | IllegalArgumentException | InvocationTargetException e) {

            Throwable actualException = e.getCause();

            actualException.printStackTrace();

        }

    }

}

java.lang.NullPointerException
at org.arpit.java2blog.StringUtils.getLengthOfString(StringUtils.java:7)
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.base/java.lang.reflect.Method.invoke(Method.java:567)
at org.arpit.java2blog.ReflectionMain.main(ReflectionMain.java:16)

To resolve InvocationTargetException, you need to solve underlying Exception(NullPointerException) in above example.
Let’s handle the null check in StringUtils.java class and you won’t get any exception anymore.

package org.arpit.java2blog;

public class StringUtils {

    public int getLengthOfString(String str) {

        if (str != null) {

            return str.length();

        } else

            return 0;

    }

}

Now when we run ReflectionMain.java again, you will see below output:

0

That’s all about java.lang.reflect.InvocationTargetException in java.

If a InvocationTargetException is a checked exception in Java that wraps an exception thrown by an invoked method or constructor. The method or constructor that throws the exception is invoked using the Method.invoke() method. The InvocationTargetException is quite common when using the Java Reflection API.

The Java reflection layer wraps any exception as an InvocationTargetException. This helps clarify whether the exception is caused by an issue in the reflection call or within the called method.

What Causes InvocationTargetException

The InvocationTargetException occurs mainly when working with the Java reflection API to invoke a method or constructor, which throws an exception.

This underlying exception is the actual cause of the issue, therefore resolving the InvocationTargetException equates to finding and resolving the underlying exception that occurs within the invoked method.

InvocationTargetException Example

Here is an example of a InvocationTargetException thrown when a method that is called using Method.invoke() throws an exception:

import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;

public class InvocationTargetExceptionExample {
    public int divideByZero() {
                return 1 / 0;
        }

    public static void main(String[] args) throws NoSuchMethodException, IllegalAccessException {
        InvocationTargetExceptionExample itee = new InvocationTargetExceptionExample(); 
        Method method = InvocationTargetExceptionExample.class.getMethod("divideByZero");
        try {
            method.invoke(itee);
        } catch (InvocationTargetException ite) {
            ite.printStackTrace();
        }
        }
}

In this example, the main() method invokes divideByZero() using Method.invoke(). Since divideByZero() throws an ArithmeticException, it is wrapped within an InvocationTargetException thrown in the main() method:

java.lang.reflect.InvocationTargetException
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.base/java.lang.reflect.Method.invoke(Method.java:564)
    at InvocationTargetExceptionExample.main(InvocationTargetExceptionExample.java:13)
Caused by: java.lang.ArithmeticException: / by zero
    at InvocationTargetExceptionExample.divideByZero(InvocationTargetExceptionExample.java:6)
    ... 5 more

How to Resolve InvocationTargetException

Since the underlying exception is the actual cause of the InvocationTargetException, finding and resolving the underlying exception resolves the InvocationTargetException. The getCause() method of the Throwable class can be used to obtain the underlying exception. The earlier example can be updated accordingly to get the underlying exception and print its stack trace:

import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;

public class InvocationTargetExceptionExample {
    public int divideByZero() {
        return 1 / 0;
    }

    public static void main(String[] args) throws NoSuchMethodException {
        InvocationTargetExceptionExample itee = new InvocationTargetExceptionExample();
        Method method = InvocationTargetExceptionExample.class.getMethod("divideByZero");
        try {
            method.invoke(itee);
        } catch (InvocationTargetException ite) {
            Throwable underlyingException = ite.getCause();
            underlyingException.printStackTrace();
        } catch (IllegalAccessException iae) {
            iae.printStackTrace();
        }
    }
}

Running the above will print out the stack trace of the underlying ArithmeticException:

java.lang.ArithmeticException: / by zero
    at InvocationTargetExceptionExample.divideByZero(InvocationTargetExceptionExample.java:6)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.base/java.lang.reflect.Method.invoke(Method.java:564)
    at InvocationTargetExceptionExample.main(InvocationTargetExceptionExample.java:13)

The stack trace can then be inspected to resolve the underlying exception. This will also resolve the wrapped InvocationTargetException.

Track, Analyze and Manage Java Errors With Rollbar

Rollbar in action

Managing errors and exceptions in your code is challenging. It can make deploying production code an unnerving experience. Being able to track, analyze, and manage errors in real-time can help you to proceed with more confidence. Rollbar automates Java error monitoring and triaging, making fixing errors easier than ever. Try it today.


public

class
InvocationTargetException

extends ReflectiveOperationException

java.lang.Object
   ↳ java.lang.Throwable
     ↳ java.lang.Exception
       ↳ java.lang.ReflectiveOperationException
         ↳ java.lang.reflect.InvocationTargetException


InvocationTargetException is a checked exception that wraps
an exception thrown by an invoked method or constructor.

As of release 1.4, this exception has been retrofitted to conform to
the general purpose exception-chaining mechanism. The «target exception»
that is provided at construction time and accessed via the
getTargetException() method is now known as the cause,
and may be accessed via the Throwable#getCause() method,
as well as the aforementioned «legacy method.»

Summary

Public constructors


InvocationTargetException(Throwable target)

Constructs a InvocationTargetException with a target exception.


InvocationTargetException(Throwable target, String s)

Constructs a InvocationTargetException with a target exception
and a detail message.

Protected constructors


InvocationTargetException()

Constructs an InvocationTargetException with
null as the target exception.

Public methods

Throwable


getCause()

Returns the cause of this exception (the thrown target exception,
which may be null).

Throwable


getTargetException()

Get the thrown target exception.

Inherited methods

From class

java.lang.Throwable


final

void


addSuppressed(Throwable exception)

Appends the specified exception to the exceptions that were
suppressed in order to deliver this exception.

Throwable


fillInStackTrace()

Fills in the execution stack trace.

Throwable


getCause()

Returns the cause of this throwable or null if the
cause is nonexistent or unknown.

String


getLocalizedMessage()

Creates a localized description of this throwable.

String


getMessage()

Returns the detail message string of this throwable.

StackTraceElement[]


getStackTrace()

Provides programmatic access to the stack trace information printed by
printStackTrace().

final

Throwable[]


getSuppressed()

Returns an array containing all of the exceptions that were
suppressed, typically by the try-with-resources
statement, in order to deliver this exception.

Throwable


initCause(Throwable cause)

Initializes the cause of this throwable to the specified value.

void


printStackTrace()

Prints this throwable and its backtrace to the
standard error stream.

void


printStackTrace(PrintWriter s)

Prints this throwable and its backtrace to the specified
print writer.

void


printStackTrace(PrintStream s)

Prints this throwable and its backtrace to the specified print stream.

void


setStackTrace(StackTraceElement[] stackTrace)

Sets the stack trace elements that will be returned by
getStackTrace() and printed by printStackTrace()
and related methods.

String


toString()

Returns a short description of this throwable.

From class

java.lang.Object


Object


clone()

Creates and returns a copy of this object.

boolean


equals(Object obj)

Indicates whether some other object is «equal to» this one.

void


finalize()

Called by the garbage collector on an object when garbage collection
determines that there are no more references to the object.

final

Class<?>


getClass()

Returns the runtime class of this Object.

int


hashCode()

Returns a hash code value for the object.

final

void


notify()

Wakes up a single thread that is waiting on this object’s
monitor.

final

void


notifyAll()

Wakes up all threads that are waiting on this object’s monitor.

String


toString()

Returns a string representation of the object.

final

void


wait(long timeoutMillis, int nanos)

Causes the current thread to wait until it is awakened, typically
by being notified or interrupted, or until a
certain amount of real time has elapsed.

final

void


wait(long timeoutMillis)

Causes the current thread to wait until it is awakened, typically
by being notified or interrupted, or until a
certain amount of real time has elapsed.

final

void


wait()

Causes the current thread to wait until it is awakened, typically
by being notified or interrupted.

Public constructors

InvocationTargetException

public InvocationTargetException (Throwable target)

Constructs a InvocationTargetException with a target exception.

Parameters
target Throwable: the target exception

InvocationTargetException

public InvocationTargetException (Throwable target, 
                String s)

Constructs a InvocationTargetException with a target exception
and a detail message.

Parameters
target Throwable: the target exception
s String: the detail message

Protected constructors

InvocationTargetException

protected InvocationTargetException ()

Constructs an InvocationTargetException with
null as the target exception.

Public methods

getCause

public Throwable getCause ()

Returns the cause of this exception (the thrown target exception,
which may be null).

Returns
Throwable the cause of this exception.

getTargetException

public Throwable getTargetException ()

Get the thrown target exception.

This method predates the general-purpose exception chaining facility.
The Throwable#getCause() method is now the preferred means of
obtaining this information.

Returns
Throwable the thrown target exception (cause of this exception).

Понравилась статья? Поделить с друзьями:
  • Java lang reflect invocationtargetexception null как исправить
  • Java lang reflect invocationtargetexception no error message
  • Java lang outofmemoryerror no error message
  • Java lang outofmemoryerror java heap space как исправить майнкрафт
  • Java lang outofmemoryerror gc overhead limit exceeded как исправить