| page.title=Reading and Writing Logs |
| parent.title=Debugging |
| parent.link=index.html |
| @jd:body |
| |
| <div id="qv-wrapper"> |
| <div id="qv"> |
| <h2>In this document</h2> |
| |
| <ol> |
| <li><a href="#logClass">The Log class</a></li> |
| |
| <li><a href="#startingLogcat">Starting LogCat</a></li> |
| |
| <li><a href="#filteringOutput">Filtering Log Output</a></li> |
| |
| <li><a href="#outputFormat">Controlling Log Output Format</a></li> |
| |
| <li><a href="#alternativeBuffers">Viewing Alternative Log Output Buffers</a></li> |
| |
| <li><a href="#viewingStd">Viewing stdout and stderr</a></li> |
| |
| <li><a href="#DebuggingWebPages">Debugging Web Pages</a></li> |
| </ol> |
| </div> |
| </div> |
| |
| <p>The Android logging system provides a mechanism for collecting and viewing system debug |
| output. Logcat dumps a log of system messages, which include things such as stack traces when the |
| emulator throws an error and messages that you have written from your application by using the |
| {@link android.util.Log} class. You can run LogCat through ADB or from DDMS, which allows you to |
| read the messages in real time.</p> |
| |
| <h2 id="logClass">The <code>Log</code> class</h2> |
| |
| <p>{@link android.util.Log} is a logging class that you can utilize in your code to print out |
| messages to the LogCat. Common logging methods include:</p> |
| |
| <ul> |
| <li>{@link android.util.Log#v(String,String)} (verbose)</li> |
| |
| <li>{@link android.util.Log#d(String,String)} (debug)</li> |
| |
| <li>{@link android.util.Log#i(String,String)} (information)</li> |
| |
| <li>{@link android.util.Log#w(String,String)} (warning)</li> |
| |
| <li>{@link android.util.Log#e(String,String)} (error)</li> |
| </ul>For example: |
| <pre class="no-pretty-print"> |
| Log.i("MyActivity", "MyClass.getView() — get item number " + position); |
| </pre> |
| |
| <p>The LogCat will then output something like:</p> |
| <pre class="no-pretty-print"> |
| I/MyActivity( 1557): MyClass.getView() — get item number 1 |
| </pre> |
| |
| <h2 id="startingLogcat">Using LogCat</h2> |
| |
| <p>You can use LogCat from within DDMS or call it on an ADB shell. For more information on how to |
| use LogCat within DDMS, see <a href="{@docRoot}tools/debugging/ddms.html#logcat">Using |
| DDMS</a>. To run LogCat, through the ADB shell, the general usage is:</p> |
| <pre> |
| [adb] logcat [<option>] ... [<filter-spec>] ... |
| </pre> |
| |
| <p>You can use the <code>logcat</code> command from your development computer or from a remote |
| adb shell in an emulator/device instance. To view log output in your development computer, you |
| use</p> |
| <pre> |
| $ adb logcat |
| </pre> |
| |
| <p>and from a remote adb shell you use</p> |
| <pre> |
| # logcat |
| </pre> |
| |
| <p>The following table describes the <code>logcat</code> command line options:</p> |
| |
| <table> |
| <tr> |
| <td><code>-c</code></td> |
| |
| <td>Clears (flushes) the entire log and exits.</td> |
| </tr> |
| |
| <tr> |
| <td><code>-d</code></td> |
| |
| <td>Dumps the log to the screen and exits.</td> |
| </tr> |
| |
| <tr> |
| <td><code>-f <filename></code></td> |
| |
| <td>Writes log message output to <code><filename></code>. The default is |
| <code>stdout</code>.</td> |
| </tr> |
| |
| <tr> |
| <td><code>-g</code></td> |
| <td>Prints the size of the specified log buffer and exits.</td> |
| </tr> |
| |
| <tr> |
| <td><code>-n <count></code></td> |
| |
| <td>Sets the maximum number of rotated logs to <code><count></code>. The default value |
| is 4. Requires the <code>-r</code> option.</td> |
| </tr> |
| |
| <tr> |
| <td><code>-r <kbytes></code></td> |
| |
| <td>Rotates the log file every <code><kbytes></code> of output. The default value is |
| 16. Requires the <code>-f</code> option.</td> |
| </tr> |
| |
| <tr> |
| <td><code>-s</code></td> |
| |
| <td>Sets the default filter spec to silent.</td> |
| </tr> |
| |
| <tr> |
| <td><code>-v <format></code></td> |
| |
| <td>Sets the output format for log messages. The default is <code>brief</code> format. For a |
| list of supported formats, see <a href="#outputFormat">Controlling Log Output |
| Format</a>.</td> |
| </tr> |
| </table> |
| |
| <h3 id="filteringOutput">Filtering Log Output</h3> |
| |
| <p>Every Android log message has a <em>tag</em> and a <em>priority</em> associated with it.</p> |
| |
| <ul> |
| <li>The tag of a log message is a short string indicating the system component from which the |
| message originates (for example, "View" for the view system).</li> |
| |
| <li>The priority is one of the following character values, ordered from lowest to highest |
| priority:</li> |
| |
| <li style="list-style: none; display: inline"> |
| <ul> |
| <li><code>V</code> — Verbose (lowest priority)</li> |
| |
| <li><code>D</code> — Debug</li> |
| |
| <li><code>I</code> — Info</li> |
| |
| <li><code>W</code> — Warning</li> |
| |
| <li><code>E</code> — Error</li> |
| |
| <li><code>F</code> — Fatal</li> |
| |
| <li><code>S</code> — Silent (highest priority, on which nothing is ever printed)</li> |
| </ul> |
| </li> |
| </ul> |
| |
| <p>You can obtain a list of tags used in the system, together with priorities, by running |
| LogCat and observing the first two columns of each message, given as |
| <code><priority>/<tag></code>.</p> |
| |
| <p>Here's an example of logcat output that shows that the message relates to priority level "I" |
| and tag "ActivityManager":</p> |
| <pre> |
| I/ActivityManager( 585): Starting activity: Intent { action=android.intent.action...} |
| </pre> |
| |
| <p>To reduce the log output to a manageable level, you can restrict log output using <em>filter |
| expressions</em>. Filter expressions let you indicate to the system the tags-priority |
| combinations that you are interested in — the system suppresses other messages for the |
| specified tags.</p> |
| |
| <p>A filter expression follows this format <code>tag:priority ...</code>, where <code>tag</code> |
| indicates the tag of interest and <code>priority</code> indicates the <em>minimum</em> level of |
| priority to report for that tag. Messages for that tag at or above the specified priority are |
| written to the log. You can supply any number of <code>tag:priority</code> specifications in a |
| single filter expression. The series of specifications is whitespace-delimited.</p> |
| |
| <p>Here's an example of a filter expression that suppresses all log messages except those with |
| the tag "ActivityManager", at priority "Info" or above, and all log messages with tag "MyApp", |
| with priority "Debug" or above:</p> |
| <pre> |
| adb logcat ActivityManager:I MyApp:D *:S |
| </pre> |
| |
| <p>The final element in the above expression, <code>*:S</code>, sets the priority level for all |
| tags to "silent", thus ensuring only log messages with "View" and "MyApp" are displayed. Using |
| <code>*:S</code> is an excellent way to ensure that log output is restricted to the filters that |
| you have explicitly specified — it lets your filters serve as a "whitelist" for log |
| output.</p> |
| |
| <p>The following filter expression displays all log messages with priority level "warning" and higher, on all tags:</p> |
| <pre> |
| adb logcat *:W |
| </pre> |
| |
| <p>If you're running LogCat from your development computer (versus running it on a |
| remote adb shell), you can also set a default filter expression by exporting a value for the |
| environment variable <code>ANDROID_LOG_TAGS</code>:</p> |
| <pre> |
| export ANDROID_LOG_TAGS="ActivityManager:I MyApp:D *:S" |
| </pre> |
| |
| <p>Note that <code>ANDROID_LOG_TAGS</code> filter is not exported to the emulator/device |
| instance, if you are running LogCat from a remote shell or using <code>adb shell |
| logcat</code>.</p> |
| |
| <h3 id="outputFormat">Controlling Log Output Format</h3> |
| |
| <p>Log messages contain a number of metadata fields, in addition to the tag and priority. You can |
| modify the output format for messages so that they display a specific metadata field. To do so, |
| you use the <code>-v</code> option and specify one of the supported output formats listed |
| below.</p> |
| |
| <ul> |
| <li><code>brief</code> — Display priority/tag and PID of the process issuing the |
| message (the default format).</li> |
| |
| <li><code>process</code> — Display PID only.</li> |
| |
| <li><code>tag</code> — Display the priority/tag only.</li> |
| |
| <li><code>raw</code> — Display the raw log message, with no other metadata fields.</li> |
| |
| <li><code>time</code> — Display the date, invocation time, priority/tag, and PID of the |
| process issuing the message.</li> |
| |
| <li><code>threadtime</code> — Display the date, invocation time, priority, tag, and |
| the PID and TID of the thread issuing the message.</li> |
| |
| <li><code>long</code> — Display all metadata fields and separate messages with blank |
| lines.</li> |
| </ul> |
| |
| <p>When starting LogCat, you can specify the output format you want by using the |
| <code>-v</code> option:</p> |
| <pre> |
| [adb] logcat [-v <format>] |
| </pre> |
| |
| <p>Here's an example that shows how to generate messages in <code>thread</code> output |
| format:</p> |
| <pre> |
| adb logcat -v thread |
| </pre> |
| |
| <p>Note that you can only specify one output format with the <code>-v</code> option.</p> |
| |
| <h3 id="alternativeBuffers">Viewing Alternative Log Buffers</h3> |
| |
| <p>The Android logging system keeps multiple circular buffers for log messages, and not all of |
| the log messages are sent to the default circular buffer. To see additional log messages, you can |
| run the <code>logcat</code> command with the <code>-b</code> option, to request viewing of an alternate |
| circular buffer. You can view any of these alternate buffers:</p> |
| |
| <ul> |
| <li><code>radio</code> — View the buffer that contains radio/telephony related |
| messages.</li> |
| |
| <li><code>events</code> — View the buffer containing events-related messages.</li> |
| |
| <li><code>main</code> — View the main log buffer (default)</li> |
| </ul> |
| |
| <p>The usage of the <code>-b</code> option is:</p> |
| <pre> |
| [adb] logcat [-b <buffer>] |
| </pre> |
| |
| <p>Here's an example of how to view a log buffer containing radio and telephony messages:</p> |
| <pre> |
| adb logcat -b radio |
| </pre><a name="stdout" |
| id="stdout"></a> |
| |
| <h2 id="viewingStd">Viewing stdout and stderr</h2> |
| |
| <p>By default, the Android system sends <code>stdout</code> and <code>stderr</code> |
| (<code>System.out</code> and <code>System.err</code>) output to <code>/dev/null</code>. In |
| processes that run the Dalvik VM, you can have the system write a copy of the output to the log |
| file. In this case, the system writes the messages to the log using the log tags |
| <code>stdout</code> and <code>stderr</code>, both with priority <code>I</code>.</p> |
| |
| <p>To route the output in this way, you stop a running emulator/device instance and then use the |
| shell command <code>setprop</code> to enable the redirection of output. Here's how you do it:</p> |
| <pre> |
| $ adb shell stop |
| $ adb shell setprop log.redirect-stdio true |
| $ adb shell start |
| </pre> |
| |
| <p>The system retains this setting until you terminate the emulator/device instance. To use the |
| setting as a default on the emulator/device instance, you can add an entry to |
| <code>/data/local.prop</code> on the device.</p> |
| |
| <h2 id="DebuggingWebPages">Debugging Web Apps</h2> |
| <p> |
| If you're developing a web application for Android, you can debug your JavaScript using the console JavaScript APIs, |
| which output messages to LogCat. For more information, see |
| <a href="{@docRoot}guide/webapps/debugging.html">Debugging Web Apps</a>.</p> |