Debugging is the process of examining your application for errors. The process of debugging is accomplished by setting breakpoints and watches in your code and running it in the debugger. This enables you to execute your code one line at a time and examine the state of your application in order to discover any problems.
The Java Debug Wire Protocol (JDWP) used by the IDE is heavy for a small VM such as that provided by the Java Card RI. Consequently, the Java Card RI uses KVM Debug Wire Protocol (KDWP) to provide a minimum set of debugging capabilities. The debugproxy translates and sends the translated JDWP commands from the IDE to the Java Card RI in KDWP format. Responses from the Java Card RI are converted into JDWP format by debugproxy before it sends them to the IDE.
The communication between the Java Card RI, debugproxy, and the IDE happens through sockets. Socket based communication enables developers to debug cjcre from remote hosts. For example, the Java Card RI could run on machine1, debugproxy could run on machine2, and the IDE could run on machine3. Developers can also run the Java Card RI, debugproxy, and the IDE on same host.
Ports used by IDE communication to and from debugproxy and debugproxy communication to and from the Java Card RI are distinguished by the names “listen port” and “remote port” respectively.
The Java Card platform debugger uses IDE menus and procedures for debugging applications. When you start a debugging session, the debugger windows appear automatically at the bottom of your screen. You can also debug applications that are running on a remote machine by attaching the debugger to the application process. See the appropriate Java Card 3 platform documentation on the Java Card 3 Kenai project site for detailed information about the Java Card 3 platform debugging protocol and procedures.
The following topics describe the basic sequence of activities completed by a developer when debugging an application for the Java Card 3 platform:
| Task | Use the IDE to: | 
| Prepare to run the debugger | 
 | 
| Run the debugger | 
 | 
| Monitor your code | 
 | 
| Finish the debugger session | 
 |