Module jdk.jdi
The Java Debug Interface (JDI) is a high level Java API providing information useful for debuggers and similar systems needing access to the running state of a (usually remote) virtual machine.
JDI provides introspective access to a running virtual machine's state, Class, Array, Interface, and primitive types, and instances of those types.
JDI also provides explicit control over a virtual machine's execution. The ability to suspend and resume threads, and to set breakpoints, watchpoints, etc. Notification of exceptions, class loading, thread creation, etc. The ability to inspect a suspended thread's state, local variables, stack backtrace, etc.
JDI is the highest-layer of the Java Platform Debugger Architecture (JPDA).
This module includes a simple command-line debugger, jdb.
Global Exceptions
This section documents exceptions which apply to the entire API and are thus not documented on individual methods.
NOTE: The exceptions below may be thrown whenever the specified conditions are met but a guarantee that they are thrown only exists when a valid result cannot be returned.Any method on a
Mirror
that takes aMirror
as an parameter directly or indirectly (e.g., as a element in aList
) will throwVMMismatchException
if the mirrors are from different virtual machines.Any method which takes a
Object
as an parameter will throwNullPointerException
if null is passed directly or indirectly -- unless null is explicitly mentioned as a valid parameter.
Any method on
ObjectReference
,ReferenceType
,EventRequest
,StackFrame
, orVirtualMachine
or which takes one of these directly or indirectly as an parameter may throwVMDisconnectedException
if the target VM is disconnected and theVMDisconnectEvent
has been or is available to be read from theEventQueue
.Any method on
ObjectReference
,ReferenceType
,EventRequest
,StackFrame
, orVirtualMachine
or which takes one of these directly or indirectly as an parameter may throwVMOutOfMemoryException
if the target VM has run out of memory.Any method on
ObjectReference
or which directly or indirectly takesObjectReference
as parameter may throwObjectCollectedException
if the mirrored object has been garbage collected.Any method on
ReferenceType
or which directly or indirectly takesReferenceType
as parameter may throwObjectCollectedException
if the mirrored type has been unloaded.
- Module Graph:
- Tool Guides:
- jdb
- Since:
- 9
- See Also:
Packages
Package | Description |
---|---|
com.sun.jdi | This is the core package of the Java Debug Interface (JDI), it defines mirrors for values, types, and the target VirtualMachine itself - as well bootstrapping facilities. |
com.sun.jdi.connect | This package defines connections between the virtual machine using the JDI and the target virtual machine. |
com.sun.jdi.connect.spi | This package comprises the interfaces and classes used to develop new TransportService implementations. |
com.sun.jdi.event | This package defines JDI events and event processing. |
com.sun.jdi.request | This package is used to request that a JDI event be sent under specified conditions. |
Services
Type | Description |
---|---|
Connector |
Type | Description |
---|---|
Connector | A method of connection between a debugger and a target VM. |
TransportService | A transport service for connections between a debugger and a target VM. |
© 1993, 2021, Oracle and/or its affiliates. All rights reserved.
Documentation extracted from Debian's OpenJDK Development Kit package.
Licensed under the GNU General Public License, version 2, with the Classpath Exception.
Various third party code in OpenJDK is licensed under different licenses (see Debian package).
Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
https://docs.oracle.com/en/java/javase/17/docs/api/jdk.jdi/module-summary.html