diff options
Diffstat (limited to 'docs/html/sdk/installing/studio-debug.jd')
| -rw-r--r-- | docs/html/sdk/installing/studio-debug.jd | 408 |
1 files changed, 0 insertions, 408 deletions
diff --git a/docs/html/sdk/installing/studio-debug.jd b/docs/html/sdk/installing/studio-debug.jd deleted file mode 100644 index b048400..0000000 --- a/docs/html/sdk/installing/studio-debug.jd +++ /dev/null @@ -1,408 +0,0 @@ -page.title=Debugging with Android Studio - -@jd:body - -<div id="qv-wrapper"> -<div id="qv"> -<h2>In this document</h2> -<ol> - <li><a href="#runDebug">Run your App in Debug Mode</a> - <ol> - <li><a href="#attachDebug">Attach the debugger to a running process</a></li> - </ol> - </li> - <li><a href="#systemLog">Use the System Log</a> - <ol> - <li><a href="#systemLogWrite">Write log messages in your code</a></li> - <li><a href="#systemLogView">View the system log</a></li> - </ol> - </li> - <li><a href="#breakPoints">Work with Breakpoints</a> - <ol> - <li><a href="#breakPointsView">View and configure breakpoints</a></li> - <li><a href="#breakPointsDebug">Debug your app with breakpoints</a></li> - </ol> - </li> - <li><a href="#allocTracker">Track Object Allocation</a></li> - <li><a href="#deviceMonitor">Analyze Runtime Metrics to Optimize your App</a></li> - <li><a href="#screenCap">Capture Screenshots and Videos</a></li> -</ol> -<h2>See also</h2> -<ul> -<li><a href="{@docRoot}sdk/installing/studio-tips.html"> -Android Studio Tips and Tricks</a></li> -<li><a href="{@docRoot}tools/debugging/index.html">Debugging</a></li> -<li><a href="{@docRoot}tools/help/monitor.html">Device Monitor</a></li> -<li><a href="{@docRoot}tools/debugging/ddms.html">Using DDMS</a></li> -</div> -</div> - -<p>Android Studio enables you to debug apps running on the emulator or on an Android device. -With Android Studio, you can:</p> - -<ul> - <li>Select a device to debug your app on.</li> - <li>View the system log.</li> - <li>Set breakpoints in your code.</li> - <li>Examine variables and evaluate expressions at run time.</li> - <li>Run the debugging tools from the Android SDK.</li> - <li>Capture screenshots and videos of your app.</li> -</ul> - -<p>To debug your app, Android Studio builds a debuggable version of your app, connects -to a device or to the emulator, installs the app and runs it. The IDE shows the system log -while your app is running and provides debugging tools to filter log messages, work with -breakpoints, and control the execution flow.</p> - - -<h2 id="runDebug">Run your App in Debug Mode</h2> - -<div class="figure" style="width:419px"> - <img src="{@docRoot}images/tools/as-debugdevices.png" alt=""/> - <p class="img-caption"><strong>Figure 1.</strong> The Choose Device window enables you to - select a physical Android device or a virtual device to debug your app.</p> -</div> - -<p>To run your app in debug mode, you build an APK signed with a debug key and install it on a -physical Android device or on the Android emulator. -To set up an Android device for development, see <a href="{@docRoot}tools/device.html">Using -Hardware Devices</a>. For more information about the emulator provided by the Android SDK, see -<a href="{@docRoot}tools/devices/emulator.html">Using the Emulator.</a></p> - -<p>To debug your app in Android Studio:</p> - -<ol> - <li>Open your project in Android Studio.</li> - <li>Click <strong>Debug</strong> <img src="{@docRoot}images/tools/as-debugbutton.png" - style="vertical-align:bottom;margin:0;height:22px" alt=""/> in the toolbar.</li> - <li>On the <em>Choose Device</em> window, select a hardware device from the list or - choose a virtual device.</li> - <li>Click <strong>OK</strong>. Your app starts on the selected device.</li> -</ol> - -<p>Figure 1 shows the <em>Choose Device</em> window. The list shows all the Android devices -connected to your computer. Select <strong>Launch Emulator</strong> to use an Android virtual device -instead. Click the ellipsis <img src="{@docRoot}images/tools/as-launchavdm.png" -style="vertical-align:bottom;margin:0;height:19px" alt=""/> to open the -<a href="{@docRoot}tools/devices/managing-avds.html">Android Virtual Device Manager</a>.</p> - -<p>Android Studio opens the <em>Debug</em> tool window when you debug your app. To open the -<em>Debug</em> window manually, click <strong>Debug</strong> -<img src="{@docRoot}images/tools/as-debugwindowbutton.png" -alt="" style="vertical-align:bottom;margin:0;height:20px"/>. -This window shows threads and variables in the <em>Debugger</em> tab, the device status in the -<em>Console</em> tab, and the system log in the <em>Logcat</em> tab. The <em>Debug</em> tool -window also provides other debugging tools covered in the following sections.</p> - -<img src="{@docRoot}images/tools/as-debugview.png" alt="" /> -<p class="img-caption"><strong>Figure 2.</strong> The Debug tool window in Android Studio showing -the current thread and the object tree for a variable.</p> - -<h3 id="attachDebug">Attach the debugger to a running process</h3> - -<p>You don't always have to restart your app to debug it. To debug an app that you're already -running:</p> - -<ol> -<li>Click <strong>Attach debugger to Android proccess</strong> -<img src="{@docRoot}images/tools/as-attach.png" alt="" -style="vertical-align:bottom;margin:0;height:20px"/>.</li> -<li>In the <em>Choose Process</em> window, select the device and app you want to attach the -debugger to.</li> -<li>To open the <em>Debug</em> tool window, click <strong>Debug</strong> -<img src="{@docRoot}images/tools/as-debugwindowbutton.png" -alt="" style="vertical-align:bottom;margin:0;height:20px"/>.</li> -</ol> - - -<h2 id="systemLog">Use the System Log</h2> - -<p>The system log shows system messages while you debug your app. These messages include -information from apps running on the device. If you want to use the -system log to debug your app, make sure your code writes log messages and prints the stack -trace for exceptions while your app is in the development phase.</p> - -<h3 id="systemLogWrite">Write log messages in your code</h3> - -<p>To write log messages in your code, use the {@link android.util.Log} class. Log messages -help you understand the execution flow by collecting the system debug output while you interact -with your app. Log messages can tell you what part of your application failed. For more -information about logging, see <a href="{@docRoot}tools/debugging/debugging-log.html"> -Reading and Writing Logs</a>.</p> - -<p>The following example shows how you might add log messages to determine if previous state -information is available when your activity starts:</p> - -<pre> -import android.util.Log; -... -public class MyActivity extends Activity { - private static final String TAG = MyActivity.class.getSimpleName(); - ... - @Override - public void onCreate(Bundle savedInstanceState) { - if (savedInstanceState != null) { - Log.d(TAG, "onCreate() Restoring previous state"); - /* restore state */ - } else { - Log.d(TAG, "onCreate() No saved state available"); - /* initialize app */ - } - } -} -</pre> - -<p>During development, your code can also catch exceptions and write the stack trace to the system -log:</p> - -<pre> -void someOtherMethod() { - try { - ... - } catch (SomeException e) { - Log.d(TAG, "someOtherMethod()", e); - } -} -</pre> - -<p class="note"><strong>Note:</strong> Remove debug log messages and stack trace print calls from -your code when you are ready to publish your app. You could do this by setting a <code>DEBUG</code> -flag and placing debug log messages inside conditional statements.</p> - - -<h3 id="systemLogView">View the system log</h3> - -<p>Both the <em>Android DDMS</em> (Dalvik Debug Monitor Server) and the <em>Debug</em> tool windows -show the system log; however, the <em>Android DDMS</em> tool window lets you view only log messages -for a particular process. To view the system log on the <em>Android DDMS</em> tool window:</p> - -<ol> - <li>Start your app as described in <a href="#runDebug">Run your App in Debug Mode</a>.</li> - <li>Click <strong>Android</strong> <img src="{@docRoot}images/tools/as-android.png" alt="" - style="vertical-align:bottom;margin:0;height:20px"/> to open the <em>Android DDMS</em> - tool window.</li> - <li>If the system log is empty in the <em>Logcat view</em>, click <strong>Restart</strong> - <img src="{@docRoot}images/tools/as-restart.png" alt="" - style="vertical-align:bottom;margin:0;height:22px"/>.</li> -</ol> - -<img src="{@docRoot}images/tools/as-ddmslog.png" alt="" /> -<p class="img-caption"><strong>Figure 4.</strong> The system log in the Android DDMS tool -window.</p> - -<p>The <em>Android DDMS</em> tool window gives you access to some DDMS features from Android Studio. -For more information about DDMS, see <a href="{@docRoot}tools/debugging/ddms.html">Using DDMS</a>. -</p> - -<p>The system log shows messages from Android services and other Android apps. To filter the log -messages to view only the ones you are interested in, use the tools in the <em>Android DDMS</em> -window:</p> - -<ul> - <li>To show only log messages for a particular process, select the process in the - <em>Devices</em> view and then click <strong>Only Show Logcat from Selected - Process</strong> <img src="{@docRoot}images/tools/as-currentproc.png" alt="" - style="vertical-align:bottom;margin:0;height:20px"/>. If the <em>Devices</em> view - is not available, click <strong>Restore Devices View</strong> - <img src="{@docRoot}images/tools/as-showdevview.png" alt="" - style="vertical-align:bottom;margin:0;height:20px"/> on the right of the <em>Android - DDMS</em> tool window. This button is only visible when you hide the <em>Devices</em> - window.</li> - <li>To filter log messages by log level, select a level under <em>Log Level</em> on the top - of the <em>Android DDMS</em> window.</li> - <li>To show only log messages that contain a particular string, enter the string in the search - box and press <strong>Enter</strong>.</li> -</ul> - - -<h2 id="breakPoints">Work with Breakpoints</h2> - -<p>Breakpoints enable you to pause the execution of your app at a particular line of code, examine -variables, evaluate expressions, and continue the execution line by line. Use breakpoints to -determine the causes of run-time errors that you can't fix by looking at your code only. To debug -your app using breakpoints:</p> - -<ol> - <li>Open the source file in which you want to set a breakpoint.</li> - <li>Locate the line where you want to set a breakpoint and click on it.</li> - <li>Click on the yellow portion of the side bar to the left of this line, as shown in figure 5.</li> - <li>Start your app as described in <a href="#runDebug">Run your App in Debug Mode</a>.</li> -</ol> - -<p>Android Studio pauses the execution of your app when it reaches the breakpoint. You can then -use the tools in the <em>Debug</em> tool window to identify the cause of the error.</p> - -<img src="{@docRoot}images/tools/as-breakpointline.png" alt="" /> -<p class="img-caption"><strong>Figure 5.</strong> A red dot appears next to the line when you set -a breakpoint.</p> - -<h3 id="breakPointsView">View and configure breakpoints</h3> - -<p>To view all the breakpoints and configure breakpoint settings, click <strong>View -Breakpoints</strong> <img src="{@docRoot}images/tools/as-viewbreakbutton.png" alt="" -style="vertical-align:bottom;margin:0;height:20px"/> on the left side of the <em>Debug</em> tool -window. The <em>Breakpoints</em> window appears, as shown in figure 6.</p> - -<img src="{@docRoot}images/tools/as-breakpointswindow.png" alt="" /> -<p class="img-caption"><strong>Figure 6.</strong> The Breakpoints window lists all the current -breakpoints and includes behavior settings for each.</p> - -<p>The <em>Breakpoints</em> window lets you enable or disable each breakpoint from the -list on the left. If a breakpoint is disabled, Android Studio does not pause your app when -it hits that breakpoint. Select a breakpoint from the list to configure its settings. -You can configure a breakpoint to be disabled at first and have the system enable it after a -different breakpoint is hit. You can also configure whether a breakpoint should be disabled after -it is hit. To set a breakpoint for any exception, select <strong>Exception Breakpoints</strong> -in the list of breakpoints.</p> - -<h3 id="breakPointsDebug">Debug your app with breakpoints</h3> - -<p>After you set breakpoints in your code, click <strong>Rerun</strong> -<img src="{@docRoot}images/tools/as-restart.png" alt="" -style="vertical-align:bottom;margin:0;height:20px"/> to start the app again. When a breakpoint is -hit, Android Studio pauses the app and highlights the breakpoint in the source code. The -<em>Debug</em> tool window lets you examine variables and control the execution step by -step:</p> - -<ul> - <li> - <p>To examine the object tree for a variable, expand it in the <em>Variables</em> view. If - the <em>Variables</em> view is not visible, click <strong>Restore Variables View</strong> - <img src="{@docRoot}images/tools/as-varviewbutton.png" alt="" - style="vertical-align:bottom;margin:0;height:20px"/>.</p> - </li> - <li> - <p>To evaluate an expression at the current execution point, click <strong>Evaluate - Expression</strong> <img src="{@docRoot}images/tools/as-evalexpbutton.png" alt="" - style="vertical-align:bottom;margin:0;height:20px"/>.</p> - </li> - <li> - <p>To advance to the next line in the code (without entering a method), click <strong>Step - Over</strong> <img src="{@docRoot}images/tools/as-stepoverbutton.png" alt="" - style="vertical-align:bottom;margin:0;height:20px"/>.</p> - </li> - <li> - <p>To advance to the first line inside a method call, click <strong>Step - Into</strong> <img src="{@docRoot}images/tools/as-stepintobutton.png" alt="" - style="vertical-align:bottom;margin:0;height:20px"/>.</p> - </li> - <li> - <p>To advance to the next line outside the current method, click <strong>Step - Out</strong> <img src="{@docRoot}images/tools/as-stepoutbutton.png" alt="" - style="vertical-align:bottom;margin:0;height:20px"/>.</p> - </li> - <li> - <p>To continue running the app normally, click <strong>Resume Program</strong> - <img src="{@docRoot}images/tools/as-resumeprogrambutton.png" alt="" - style="vertical-align:bottom;margin:0;height:20px"/>.</p> - </li> -</ul> - -<img src="{@docRoot}images/tools/as-variablesview.png" alt="" /> -<p class="img-caption"><strong>Figure 7.</strong> The Variables view in the Debug tool window.</p> - - -<h2 id="allocTracker">Track Object Allocation</h2> - -<p>Android Studio lets you track objects that are being allocated on the Java heap and see which -classes and threads are allocating these objects. This allows you to see the list of objects -allocated during a period of interest. This information is valuable for assessing memory usage -that can affect application performance.</p> - -<p>To track memory allocation of objects:</p> - -<ol> -<li>Start your app as described in <a href="#runDebug">Run Your App in Debug Mode</a>.</li> -<li>Click <strong>Android</strong> <img src="{@docRoot}images/tools/as-android.png" alt="" -style="vertical-align:bottom;margin:0;height:20px"/> to open the <em>Android DDMS</em> -tool window.</li> -<li>On the <em>Android DDMS</em> tool window, select the <strong>Devices | logcat tab</strong>.</li> -<li>Select your device from the dropdown list.</li> -<li>Select your app by its package name from the list of running apps.</li> -<li>Click <strong>Start Allocation Tracking</strong> -<img src="{@docRoot}images/tools/as-allocstart.png" alt="" -style="vertical-align:bottom;margin:0;height:20px"/></li> -<li>Interact with your app on the device.</li> -<li>Click <strong>Stop Allocation Tracking</strong> -<img src="{@docRoot}images/tools/as-allocstop.png" alt="" -style="vertical-align:bottom;margin:0;height:20px"/></li> -</ol> - -<p>Android Studio shows the objects that the system allocated with the following information:</p> - -<ul> -<li>Allocation order</li> -<li>Allocated class</li> -<li>Allocation size</li> -<li>Thread ID</li> -<li>Allocation method, class, and line number</li> -<li>Stack trace at the point of allocation</li> -</ul> - -<img src="{@docRoot}images/tools/as-alloctrack.png" alt="" width="750" height="252" /> -<p class="img-caption"><strong>Figure 8.</strong> Object allocation tracking in Android Studio.</p> - - -<h2 id="deviceMonitor">Analyze Runtime Metrics to Optimize your App</h2> - -<p>Even if your application does not generate runtime errors, this does not mean it is free of -problems. You should also consider the following issues:</p> - -<ul> - <li>Does your app use memory efficiently?</li> - <li>Does your app generate unnecessary network traffic?</li> - <li>What methods should you focus your attention on to improve the performance of your app?</li> - <li>Does your app behave properly when the user receives a phone call or a message?</li> -</ul> - -<p>The Android Device Monitor is a stand-alone tool with a graphical user interface for serveral -Android application debugging and analysis tools, including the Dalvik Debug Monitor Server (DDMS). -You can use the Android Device Monitor to analyze memory usage, profile methods, -monitor network traffic and simulate incoming calls and messages.</p> - -<p>To open the Android Device Monitor from Android Studio, click -<strong>Monitor</strong> <img src="{@docRoot}images/tools/as-monitorbutton.png" alt="" -style="vertical-align:bottom;margin:0;height:20px"/> on the toolbar. The Android Device Monitor -opens in a new window.</p> - -<p>For more information about the Android Device Monitor and DDMS, see -<a href="{@docRoot}tools/help/monitor.html">Device Monitor</a> and -<a href="{@docRoot}tools/debugging/ddms.html">Using DDMS</a>.</p> - - -<h2 id="screenCap">Capture Screenshots and Videos</h2> - -<p>Android Studio enables you to capture a screenshot or a short video of the device screen -while your app is running. Screenshots and videos are useful as promotional materials for your -app, and you can also attach them to bug reports that you send to your development team.</p> - -<p>To take a screenshot of your app:</p> - -<ol> - <li>Start your app as described in <a href="#runDebug">Run your App in Debug Mode</a>.</li> - <li>Click <strong>Android</strong> <img src="{@docRoot}images/tools/as-android.png" alt="" - style="vertical-align:bottom;margin:0;height:20px"/> to open the <em>Android DDMS</em> - tool window.</li> - <li>Click <strong>Screen Capture</strong> <img src="{@docRoot}images/tools/as-capture.png" - style="vertical-align:bottom;margin:0;height:22px" alt=""/> on the left side of the - <em>Android DDMS</em> tool window.</li> - <li>Optional: To add a device frame around your screenshot, enable the <em>Frame screenshot</em> - option.</li> - <li>Click <strong>Save</strong>.</li> -</ol> - -<p>To take a video recording of your app:</p> - -<ol> - <li>Start your app as described in <a href="#runDebug">Run your App in Debug Mode</a>.</li> - <li>Click <strong>Android</strong> <img src="{@docRoot}images/tools/as-android.png" alt="" - style="vertical-align:bottom;margin:0;height:20px"/> to open the <em>Android DDMS</em> - tool window.</li> - <li>Click <strong>Screen Record</strong> <img src="{@docRoot}images/tools/as-record.png" - style="vertical-align:bottom;margin:0;height:22px" alt=""/> on the left side of the - <em>Android DDMS</em> tool window.</li> - <li>Click <strong>Start Recording</strong>.</li> - <li>Interact with your app.</li> - <li>Click <strong>Stop Recording</strong>.</li> - <li>Enter a file name for the recording and click <strong>OK</strong>.</li> -</ol>
\ No newline at end of file |
