博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
《Android 应用案例开发大全(第3版)》——第1章,第1.4节DDMS的灵活应用
阅读量:6237 次
发布时间:2019-06-22

本文共 3149 字,大约阅读时间需要 10 分钟。

本节书摘来自异步社区《Android 应用案例开发大全(第3版)》一书中的第1章,第1.4节 DDMS的灵活应用,作者 吴亚峰 , 苏亚光 , 于复兴,更多章节内容可以访问云栖社区“异步社区”公众号查看

1.4 DDMS的灵活应用

作为一名合格的软件开发人员,必须要学会怎样去调试程序。调试是一个程序员最基本的技能,其重要性甚至超过学好一门语言。那么什么是调试呢?所谓调试,就是在软件投入实际使用前,用手工或编译程序等方法进行测试,修正语法错误和逻辑错误的过程。这是保证软件系统正确性的必不可少的步骤。

Android为开发人员提供了一个强大的调试工具——DDMS,通过DDMS可以调试并监控程序的运行,更好地帮助开发人员完成软件的调试和开发。本节将对DDMS的使用进行详细的讲解,帮助读者提高对软件整体的把握能力。

1.4.1 初识DDMS

一般情况下,在Eclipse中安装了ADT插件后,Eclipse窗口的右上角会有DDMS的选项按钮图片 49,如图1-36所示。若DDMS按钮图片 50是隐藏的,读者可以通过Eclipse窗口界面右上角的图片 51(Open Perstective)按钮来打开DDMS,如图1-37所示。单击图片 52按钮即可切换到DDMS界面,如图1-38所示。

a3a78a28dd6637bcc0180ee3a6c4a4fbef4da4bc

说明

该窗口的布局可自行调整,主要包括Devices(设备列表面板)、Emulator Control(模拟器控制器面板)、LogCat(日志显示面板)、Threads(线程监控面板)、Heap(内存堆监控面板)、Allocation Tracker(对象分布监控面板)、File Explorer(文件浏览器面板)等。

1.4.2 强大的日志管理功能——LogCat的使用

查看日志文件,可以使程序员完全了解程序的运行状况,从而进一步优化和修改程序代码,LogCat为开发人员提供了强大的日志管理功能,通过LogCat可以查看模拟器运行的所有状态,还可以通过过滤器来筛选出自己需要的日志。

打开DDMS后单击LogCat选项卡,打开LogCat面板,默认看到的是模拟器所有的日志,如图1-39所示,其中包括verbose、debug、info、warn、error和assert共6种类别。开发人员可以使用Java中的System.out.println()方法来打印输出,辅助调试程序。运行程序后,打印输出的内容便显示在LogCat中,如图1-39所示。

b28811578304519a83818be122a89f188d1319a9

如果读者觉得Log中有太多的无用信息,还可以自建日志过滤器,只显示自己需要的日志文件。方法是:单击LogCat面板右上角的绿色加号,弹出“LogFilter”对话框,在Filter Name中输入过滤器的名称,在by Log Tag中输入要过滤的内容,如图1-40所示即可,此时再次运行程序,选择自定义日志选项卡,可以看到日志中只有System.out的内容,如图1-41所示。

34df835c17b7b00d5b717695b6d791e0e1a917d4

1.4.3 Devices的管理

Devices选项卡提供了软件截图的功能,可以方便地对多个模拟器和模拟器的进程、线程、堆等进行管理,如图1-42所示。其中Devices面板还可以与其他面板共同使用,例如Threads选项卡、Heap选项卡等,从而进行程序线程和堆的管理。

1.Devices简介

首先介绍Devices选项卡的基本功能,如图1-42所示,这里开启了两个Android模拟器,从图中可以看到两个模拟器都出现在了Devices选项卡面板中,名称分别为emulator-5554和emulator-5556,通过单击模拟器的名称,可以在多个模拟器中进行切换。

9c45cd417e45448ce6ca8823c57561f6baf3cd66

截图功能。在模拟器中运行程序,如需要对软件运行效果进行抓图,则可在需要抓图的界面停留,然后单击“Devices”选项卡右上角的“Screen Capture”按钮,显示截图对话框。在对话框中可以预览图片,并进行刷新、图片旋转、保存、复制等,如图1-43所示。

结束进程功能。先单击选中模拟器中要结束的进程,然后单击“Devices”选项卡右上角的“Stop Process”按钮,即可强制结束进程。如要结束模拟器中的“com.anroid.music”进程,如图1-44所示。

c5252cf6445cdc5f905467e65776789133a931bb

在“Devices”面板中,还可对某一进程进行“心电图”测试。首先选中要测试的进程,单击“Devices”面板右上角的“star Method Profiling”按钮,待程序运行一段时间后,单击“Devices”面板右上角的“stop Method Profiling”按钮,等待一段时间后,自动弹出“心电图”窗口,如图1-45所示。

5e6c0381202b461ee565fa1438df5c7688894ca3

2.Devices与Threads

上面介绍的只是“Devices”面板简单的两个功能,下面介绍Devices面板与Threads面板共同使用,进行程序线程的管理。一个程序假如开太多的线程即使机器性能再好,也会慢如龟速,所以线程的控制就显得尤为重要了,线程的查看方法如下。

(1)选中“Devices”面板中要查看的程序进程。

(2)单击“Devices”面板右上角的“Update Threads”按钮。

(3)单击“Threads”选项卡,即可查看该进程的所有线程及线程的运行情况,如图1-46所示。

dfeff0ec93b54a03e28abc54d33ba0ea8d68e6a1

3.Devices与Heap

虽然当下的手机性能越来越好,手机内存当然也越来越大,但是程序过多地占用内存也是不允许的,这不仅会使程序显得很慢造成用户的不满,而且会造成程序的臃肿,甚至瘫掉。作为合格的软件开发人员,必须严格地管理自己程序的内存使用情况,在条件允许的情况下,尽量优化程序,用最小的内存完美地运行程序。堆的查看和管理方法如下。

(1)选中“Devices”面板中要查看的程序进程。

(2)单击“Devices”面板右上角的“Update Heap”按钮。

(3)单击“Heap”选项卡,在该选项卡中单击“Cause GC”按钮,即可进行程序堆的详细查看和管理,如图1-47所示。

59ecf5b6ec16149b1f8caae4eea88d16f8e6b8cb

1.4.4 模拟器控制(Emulator Control)详解

Emulator Control顾名思义,即模拟器控制。通过“Emulator Control”面板(如图1-48所示)可以非常容易地使用模拟器模拟真实手机所具备的一些交互功能,如接听电话、模拟各种不同网络环境、模拟接收SMS消息和发生虚拟的地址坐标用于测试GPS相关功能等。

d0b3c506a02ea6a086cbc1705a748d25b4361f80

Telephony Status:通过选项模拟语音质量以及信号连接模式。

Telephony Actions:模拟电话接听和发送SMS到测试终端。
Location Controls:模拟地理坐标或者模拟动态的路线坐标变化并显示预设的地理标识。
模拟地理坐标的三种方式为:Manual(手动为终端发送经纬度坐标)、GPX(通过GPX文件导入序列动态变化地理坐标,从而模拟行进中GPS变化的数值)和KML(通过KML文件导入独特的地理标识,并以动态形式根据变化的地理坐标显示在测试终端)。

1.4.5 File Explorer——SD Card文件管理器

File Explorer是Android SDK提供的管理SD Card的文件管理器。通过File Explorer可以查看程序对SD Card的使用情况,从而判断程序是否正确运行,具体步骤如下。

(1)选择要查看的模拟器。

(2)单击File Explorer选项卡,如图1-49所示。从图1-49中可以看到该管理器很类似于Windows的资源管理器,可以通过单击方便地查看任何文件。

(3)单击File Explorer选项卡右上角的两个按钮,可以方便地进行文件的导入和导出。

转载地址:http://socia.baihongyu.com/

你可能感兴趣的文章
dubbo源码解析(八)远程通信——开篇
查看>>
在Docker中使用Xdebug
查看>>
snabbdom.js(二)
查看>>
【跃迁之路】【657天】程序员高效学习方法论探索系列(实验阶段414-2018.12.01)...
查看>>
Testng(二):监听
查看>>
重构改善既有的代码设计(代码的坏味道)
查看>>
入门量子计算
查看>>
为什么全栈JavaScript经常被黑,而Java却不会被黑?
查看>>
Java设计模式的6大原则
查看>>
在2018年如何优雅的开发一个typescript语言的npm包?
查看>>
一些小小的总结
查看>>
Homestead 环境搭建
查看>>
Retrofit源码分析
查看>>
零基础兴趣或者转行学习Python,我们应该如何入门呢?
查看>>
electron 仿制QQ登录界面
查看>>
基于Spring Boot实现图片上传/加水印一把梭操作
查看>>
聊聊storm的LoggingClusterMetricsConsumer
查看>>
vue-waterfall2 基于Vue.js 瀑布流组件
查看>>
Vue一个案例引发的递归组件的使用
查看>>
Canvas 实现一个简单的贪吃蛇
查看>>