- 浏览: 672826 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
yigeisme:
你好,不已.html和.jsp和.jpg结尾的正则表达式怎么写 ...
深入入门正则表达式(java) - 2 - 基本实例 -
su1216:
多谢指正yigeisme 写道1-12(小时,月份)正则:^( ...
深入入门正则表达式(java) - 2 - 基本实例 -
yigeisme:
1-12(小时,月份)正则:^(1[012]|\d)$应该改成 ...
深入入门正则表达式(java) - 2 - 基本实例 -
heikefangxianceshi:
小三将军 写道楼主,我想问下你给的Real.tar.gz是什么 ...
android手机root后的安全问题 (一) -
heikefangxianceshi:
这个程序运行的前提是手机root,但你的手机怎么root的呢? ...
android手机root后的安全问题 (一)
dumpsys是系统中重要的函数,我们来看看它如何使用,都能dump出来一些什么东西
首先我们来看看dumpsys的源码,在4.1中,它在framework/native目录下面
frameworks/native/cmds/dumpsys/dumpsys.cpp
if (argc == 1) { services = sm->listServices(); services.sort(sort_func); args.add(String16("-a")); } else { services.add(String16(argv[1])); for (int i=2; i<argc; i++) { args.add(String16(argv[i])); } } const size_t N = services.size(); if (N > 1) { // first print a list of the current services aout << "Currently running services:" << endl; for (size_t i=0; i<N; i++) { sp<IBinder> service = sm->checkService(services[i]); if (service != NULL) { aout << " " << services[i] << endl; } } } for (size_t i=0; i<N; i++) { sp<IBinder> service = sm->checkService(services[i]); if (service != NULL) { if (N > 1) {//dump多个Service时,Service信息之间的分隔 aout << "------------------------------------------------------------" "-------------------" << endl; aout << "DUMP OF SERVICE " << services[i] << ":" << endl; } int err = service->dump(STDOUT_FILENO, args); if (err != 0) { aerr << "Error dumping service info: (" << strerror(err) << ") " << services[i] << endl; } } else { aerr << "Can't find service: " << services[i] << endl; } }
我只会java,上面的代码还是留给大家自己阅读吧,我就不详细解释了……
如果参数个数=1,则在ServiceManager中查找注册的Service
否则查找指定的Service,并且将剩余参数传给Serivce
如果执行dumpsys命令,那么将会dump所有Service,每个Service之间会分隔开
如果dumpsys一个没有注册的Service,那么则提示找不到Service,比如:
# dumpsys adb
Can't find service: adb
那么我们到底都可以dump一些什么呢?
其实最简单的办法就是执行dumpsys,看看其结果,下面是我手机中执行的结果(HTCg14)
# dumpsys Currently running services: DeviceManager3LM Encryption3LMService HtcAppUsageStatsService SurfaceFlinger accessibility account activity alarm appwidget audio backup battery batteryinfo bluetooth bluetooth_a2dp bluetooth_hid bt_fm_management clipboard connectivity content country_detector cpuinfo device_policy devicestoragemonitor diskstats display drm.drmManager dropbox entropy gfxinfo hardware htc_checkin htchardware htctelephony htctelephonyinternal input_method iphonesubinfo isms location media.audio_flinger media.audio_policy media.camera media.player meminfo mount netpolicy netstats network_management notification package permission phone power samplingprofiler search secfirewall secloader sensorservice simphonebook sip statusbar stub_activity stub_audio stub_iphonesubinfo stub_isms stub_location stub_phone stub_telephony.registry telephony.registry textservices throttle uimode usagestats usb usbnet userbehavior vibrator wallpaper wifi wifip2p window ------------------------------------------------------------------------------- DUMP OF SERVICE DeviceManager3LM: ------------------------------------------------------------------------------- DUMP OF SERVICE Encryption3LMService:
由于dump service的log实在太长,我就截取了最前面的“Currently running services”和两个Service的dump信息
为什么DeviceManager3LM和Encryption3LMService后面没有内容?这和Service的内部实现有关,也许它只是写了一个空的dump函数,也许有什么其他条件。
这个问题一会再说,我们先看看这些Service都是在哪注册的
其中大部分Service都是在SystemServer中的main函数里注册的,它调用了一个叫init2的函数
public static final void init2() { Slog.i(TAG, "Entered the Android system server!"); Thread thr = new ServerThread(); thr.setName("android.server.ServerThread"); thr.start(); }
init2非常简单,所有任务都交给新线程ServerThread来处理
在ServerThread的run函数中,注册了系统大部分的Service,有兴趣的同学可以看看这部分代码
这部分代码有点长(大概800行),因为它一直重复这建立各种Service,然后注册,输出log
比如下面的WifiP2pService
try { Slog.i(TAG, "Wi-Fi P2pService"); wifiP2p = new WifiP2pService(context); ServiceManager.addService(Context.WIFI_P2P_SERVICE, wifiP2p); } catch (Throwable e) { reportWtf("starting Wi-Fi P2pService", e); }
其中WIFI_P2P_SERVICE就是服务的名字
public static final String WIFI_P2P_SERVICE = "wifip2p";
当执行dumpsys wifip2p的时候,并没有任何输出,为什么呢?我们看看WifiP2pService的代码
@Override protected void dump(FileDescriptor fd, PrintWriter pw, String[] args) { if (mContext.checkCallingOrSelfPermission(android.Manifest.permission.DUMP) != PackageManager.PERMISSION_GRANTED) { pw.println("Permission Denial: can't dump WifiP2pService from from pid=" + Binder.getCallingPid() + ", uid=" + Binder.getCallingUid()); return; } }
现在似乎可以理解为什么dumpsys wifip2p的时候没有输出了
我们再来看一个简单的例子
# dumpsys diskstats
Latency: 5ms [512B Data Write]
Data-Free: 362888K / 1161104K total = 31% free
Cache-Free: 116756K / 120900K total = 96% free
System-Free: 133036K / 806284K total = 16% free
ServiceManager.addService("diskstats", new DiskStatsService(context));
protected void dump(FileDescriptor fd, PrintWriter pw, String[] args) { …… reportFreeSpace(Environment.getDataDirectory(), "Data", pw); reportFreeSpace(Environment.getDownloadCacheDirectory(), "Cache", pw); reportFreeSpace(new File("/system"), "System", pw); }
private void reportFreeSpace(File path, String name, PrintWriter pw) { try { StatFs statfs = new StatFs(path.getPath()); long bsize = statfs.getBlockSize(); long avail = statfs.getAvailableBlocks(); long total = statfs.getBlockCount(); if (bsize <= 0 || total <= 0) { throw new IllegalArgumentException( "Invalid stat: bsize=" + bsize + " avail=" + avail + " total=" + total); } pw.print(name); pw.print("-Free: "); pw.print(avail * bsize / 1024); pw.print("K / "); pw.print(total * bsize / 1024); pw.print("K total = "); pw.print(avail * 100 / total); pw.println("% free"); } catch (IllegalArgumentException e) { pw.print(name); pw.print("-Error: "); pw.println(e.toString()); return; } }
转贴请保留以下链接
本人blog地址
发表评论
-
android 第三方app截图
2017-08-17 15:18 1169将View生成相应的图片 ... -
android截图事件监听
2017-07-20 18:37 2007android系统没有对用户截屏行为提供回调的api,所以我 ... -
android widget(桌面小部件)实现
2017-06-30 13:02 2065本文介绍如何自己实现一个widget以及各种注意事项。 ... -
acra简析
2016-07-31 23:54 0版本4.9.1 acra是用来在 ... -
android版本差异
2016-07-28 14:42 0这里只列出部分开发相关内容 notification ... -
android系统提供的常用命令行工具
2016-06-21 13:17 5109本博客只要没有注明“转”,那么均为原创,转贴请注明本博客链 ... -
标示与掩码
2015-10-21 23:00 0掩码(英语:Mask) ... -
通过蓝牙调试(穿戴设备app) - 开发文档翻译
2015-09-30 11:43 2647由于本人英文能力实在 ... -
打包穿戴设备app - 开发文档翻译
2015-09-29 17:19 1877由于本人英文能力实在有限,不足之初敬请谅解 本博客只要没 ... -
弧形进度条(动画版)
2015-07-23 17:00 5935本博客只要没有注明“转”,那么均为原创,转贴请注明本博客链接 ... -
使用canvas与Paint在View中居中绘制文字
2015-07-15 23:03 9001本博客只要没有注明 ... -
android 关于提高第三方app的service优先级
2014-06-23 23:14 3185本博客只要没有注明“转”,那么均为原创,转贴请注明本博客链 ... -
android <application> 开发文档翻译
2014-05-24 23:47 5159由于本人英文能力实 ... -
android中各种log的抓取
2013-12-23 13:15 01.logcat的使用 2.内存快照的抓取 ... -
android多语言项目中字符串的移植(bash工具)
2013-11-11 13:31 2513有时候我们会遇到这样一种情况: 一些字符串资源要从原始项 ... -
android 高效显示Bitmap - 开发文档翻译
2013-09-13 17:59 2637由于本人英文能力实在有限,不足之初敬请谅解 本博客只要没 ... -
android 在你的UI中显示Bitmap - 开发文档翻译
2013-09-06 19:33 6636由于本人英文能力实在有限,不足之初敬请谅解 本博客只要没 ... -
android 管理Bitmap内存 - 开发文档翻译
2013-08-27 15:39 4173由于本人英文能力实在有限,不足之初敬请谅解 本博客只要没 ... -
android 缓存Bitmap - 开发文档翻译
2013-08-25 13:01 3201由于本人英文能力实在有限,不足之初敬请谅解 本博客只要没有 ... -
android 在UI线程之外处理Bitmap - 开发文档翻译
2013-08-12 13:30 3432由于本人英文能力实 ...
相关推荐
在Android手机上, 通过使用adb shell命令可以进入android系统的shell, 该shell除支持一些常用的标准命令之外,还支持一些和android系统相关的其他命令, 这些命令可以打印出系统当前的状态信息。 dumpsys就是这样...
例如,`meminfo`服务就是在`ActivityManagerService`的`setSystemProcess`函数中注册的,它用于提供内存使用情况的详细数据。 `dumpsys meminfo`命令用于查看应用的内存使用情况,包括PSS(Proportional Set Size)...
4. **使用Tracer for Android**:这是Android提供的一种性能分析工具,可以跟踪特定函数的调用时间,帮助找出性能瓶颈。通过`atrace -z`命令可以实时追踪,`atrace --async_start`和`atrace --async_stop`用于开始和...
在Android系统中,输入设备(Input Device)是用户与设备交互的重要途径,涵盖了触摸屏、键盘、鼠标等各种形式。为了使这些设备能在Android系统中正常工作,开发者需要进行相应的注册和配置。本篇将深入探讨如何在...
"android分析工具说明书.rar"这个压缩包很可能是提供了一份详尽的指南,介绍了如何使用各种Android分析工具来分析程序内存、监控对象属性变化等关键任务。 一、Android分析工具介绍 1. **Android Studio Profiler*...
在源码中,可以查看到与内存分配、释放和垃圾收集相关的函数,如`malloc()`、`free()`和GC相关的触发条件。通过阅读和理解这些源码,开发者可以更精确地了解内存分配的过程,从而找出潜在的内存泄漏问题。 接下来,...
在Android应用开发中,性能测试是确保应用质量的关键环节,特别是在资源有限的移动设备上。本文将深入探讨如何使用`procrank`等工具进行APK的性能测试,包括CPU使用率、进程内存占用等方面的检测。 一、Android APK...
代码实现中,我们可以使用 Choreographer.getInstance().postFrameCallback() 方法来注册 VSYNC 信号回调监听,当 VSYNC 信号返回时,会执行 doFrame 回调函数。 在 doFrame 方法中,我们统计每秒内的执行次数,...
### Android内存管理与工具使用详解 #### 一、内存分配跟踪工具DDMS——Allocation Tracker使用 **背景介绍:** 在Android开发中,内存管理是非常重要的一环,它直接影响着应用程序的性能和用户体验。为了帮助...
在本文中,我们将深入探讨如何使用Python通过ADB(Android Debug Bridge)来获取Android设备上特定应用的CPU和内存占用情况。这个过程对于Android应用的性能分析、优化以及故障排查至关重要。 首先,要实现这个功能,...
1. **启用TraceView**:要在应用中收集`.trace`文件,可以在代码中使用`android.os.Debug.startMethodTracing()`来启动追踪,然后在适当的位置使用`android.os.Debug.stopMethodTracing()`来停止。此外,也可以在ADB...
在Android应用开发过程中,开发者需要安装和使用这些工具来构建、调试和发布应用程序。下面将详细介绍其中包含的一些关键工具及其用途。 1. **adb (Android Debug Bridge)**:这是一个多功能命令行工具,用于连接...
3. **system-server**:Android系统中重要的守护进程之一,负责管理与协调各种系统服务。 4. **watchdog**:监视系统服务运行状态的守护进程,如果发现某些服务挂掉会自动重启这些服务,保证了系统的稳定性。 #### ...
通过以上介绍,我们可以了解到如何使用Python结合adb命令对Android应用进行自动化测试,尤其适用于解决偶发性问题的重现和压力测试。在实际工作中,可以根据具体需求调整脚本,适应不同的测试场景。
打开相应功能页面,调用命令行 adb shell dumpsys activity top 查看页面信息 新建 xxxOperation 类,继承 DefaultOperation 类,完善代码 WhiteListManager 类构造函数中注册自己的 xxxOperation 类 MainActivity ...
在Android开发和测试中,`adb (Android Debug Bridge)` 是一个强大的命令行工具,用于与连接的设备进行通信。在本教程中,我们将探讨如何使用ADB来获取安卓模拟器的点击坐标,并通过易语言(E Language)实现相关...
- 如果遇到Python中的adb版本与夜神模拟器中的adb版本不一致的问题,可以使用更高版本的adb替换低版本的adb。 - 可以创建批处理文件自动化地复制编译好的版本,并将其安装到夜神模拟器中,进一步提高自动化程度。 ...
可以使用Python的`subprocess.Popen()`函数执行`logcat`命令,监控日志输出。此外,为了检测黑屏问题,还需要定时获取CPU和内存信息,这可以通过执行`dumpsys meminfo`和`cpuinfo`命令实现。 测试结果展示了这种...