jdk/src/jdk.jdi/share/classes/jdi-overview.html
author jwilhelm
Sat, 18 Feb 2017 03:23:28 +0100
changeset 43926 55bfd293eb16
parent 30678 a8b7fd8ede97
permissions -rw-r--r--
Merge

<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML//EN">
<html>
  <head>
    <title>Java&trade; Debug Interface</title>
  </head>
  <body>
	The Java&trade; 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.
<p>
	The JDI provides introspective
access to a running virtual machine's state, Class, Array,
Interface, and primitive types, and instances of those
types.
<P>
The JDI also provides explicit control over
a virtual machine's execution. The ability to suspend
and resume threads, and to set breakpoints, watchpoints, ...
Notification
of exceptions, class loading, thread creation...
The ability to inspect a suspended thread's state,
local variables, stack backtrace...
<p>
JDI is the highest-layer of the Java Platform Debugger Architecture (JPDA).
For more information on the Java Platform Debugger Architecture, see the
<a href="{@docRoot}/../../../../technotes/guides/jpda/index.html">
Java Platform Debugger Architecture documentation</a>
for this release and the
<a href="http://java.sun.com/products/jpda">Java Platform Debugger Architecture website</a>.
<p>
<font size="+1"><b>Global Exceptions:</b></font>
<p>
This section documents exceptions which apply to the entire API and are thus
not documented on individual methods.

    <blockquote>
        <p>
        <b>{@link com.sun.jdi.VMMismatchException}</b>
        <p>
            Any method on a {@link com.sun.jdi.Mirror} that takes a <code>Mirror</code> as an
            parameter directly or indirectly (e.g., as a element in a <code>List</code>) will
            throw {@link com.sun.jdi.VMMismatchException} if the mirrors are from different
            virtual machines.
        <p>
        <b>{@link java.lang.NullPointerException}</b>
        <p>
            Any method which takes a {@link java.lang.Object} as an parameter will throw
            {@link java.lang.NullPointerException} if null is passed directly or indirectly
            -- unless null is explicitly mentioned as a valid parameter.
    </blockquote>
     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.
    <blockquote>
        <p>
        <b>{@link com.sun.jdi.VMDisconnectedException}</b>
        <p>
            Any method on {@link com.sun.jdi.ObjectReference}, {@link com.sun.jdi.ReferenceType},
            {@link com.sun.jdi.request.EventRequest}, {@link com.sun.jdi.StackFrame}, or
            {@link com.sun.jdi.VirtualMachine} or which takes one of these directly or indirectly
            as an parameter may throw {@link com.sun.jdi.VMDisconnectedException} if the target VM
            is disconnected and the {@link com.sun.jdi.event.VMDisconnectEvent} has been or is available
            to be read from the {@link com.sun.jdi.event.EventQueue}.
        <p>
        <b>{@link com.sun.jdi.VMOutOfMemoryException}</b>
        <p>
            Any method on {@link com.sun.jdi.ObjectReference}, {@link com.sun.jdi.ReferenceType},
            {@link com.sun.jdi.request.EventRequest}, {@link com.sun.jdi.StackFrame}, or
            {@link com.sun.jdi.VirtualMachine} or which takes one of these directly or indirectly
            as an parameter may throw {@link com.sun.jdi.VMOutOfMemoryException} if the target
            VM has run out of memory.
        <p>
        <b>{@link com.sun.jdi.ObjectCollectedException}</b>
        <p>
            Any method on {@link com.sun.jdi.ObjectReference} or which directly or indirectly takes
            <code>ObjectReference</code> as parameter may throw {@link com.sun.jdi.ObjectCollectedException}
            if the mirrored object has been garbage collected.
        <p>
            Any method on {@link com.sun.jdi.ReferenceType} or which directly or indirectly takes
            <code>ReferenceType</code> as parameter may throw {@link com.sun.jdi.ObjectCollectedException}
            if the mirrored type has been unloaded.

    </blockquote>
  </body>
</html>