不容错过的Android开发辅助工具App,提升效率必备神器

2026-02-08 0 845

开发阶段,若设备无法进入锁屏且屏幕不熄灭,这会成为一个重要问题。这种情况可以防止自动锁屏频繁发生,从而减少对开发进度的影响。此外,一些类似系统开发者选项但更为便捷的功能,比如不受USB线插拔影响的特点,这些也是非常有意义的探索方向。

避免自动锁屏

开发过程中,设备自动锁屏实在让人头疼。以前,这常会导致工作流程被打断。现在掌握了这种在任何情况下都能防止锁屏的技巧,工作效率显著提高。在办公室或实验室忙碌时,再也不用担心设备会突然锁屏了。这对长时间专注开发任务极为有益。锁屏会打断思路,让人重新进入状态需要花费不少时间。这种特性能有效避免这种情况。

在不同的开发环境中,我们可能会频繁地插拔USB线。例如,在进行数据迁移测试时,这样的操作尤为常见。在这种情况下,开发者选项中那些依赖USB线的锁屏设置就显得很不方便。然而,这项新功能却能持续稳定地运行,不受任何影响。

Crash的调用堆栈查看

查看缓存里记录的崩溃调用堆栈对开发来说至关重要。这样的堆栈信息可能一个也没有,也可能有好几个。遇到这类信息时,需仔细筛选出自己需要关注的Crash,这直接影响到问题解决的准确性。比如在处理大型项目时,若收到众多崩溃报告,这个功能能帮助快速缩小问题范围。

手动检查的用意在于系统可能无法自动帮你挑选出关键信息。在紧急修补漏洞、时间紧迫的时候,尤其需要准确找出问题所在。否则,很可能会让大量人力和时间消耗在无谓的查找中。

不容错过的Android开发辅助工具App,提升效率必备神器

Shell权限相关问题

不容错过的Android开发辅助工具App,提升效率必备神器

许多功能需借助Shell权限才能使用。若功能无法正常使用,很可能是因为Shell权限获取未成功。“adb tcpip 5555”这条命令能自动帮我们获取Shell权限。操作时,需注意输入指令是否准确,比如检查指令中是否有误输入空格或大小写问题。

权限获取失败会导致功能使用受限制。比如,以前有次因为Shell权限问题没及时解决,结果组件检查等好几个功能都用不了,这耽误了整个项目的开发进度。在那些时间安排很紧张的项目中,这种错误是承担不起的。

# adb shell am ...  set-debug-app [-w] [--persistent]       Set application <PACKAGE> to debug.  Options are:      -w: wait for debugger when application starts      --persistent: retain this value  clear-debug-app      Clear the previously set-debug-app....

组件检查的重要性


迅速浏览组件的品种、标识、色调等信息,对于确保检查工作至关重要。这样做有助于在问题出现时迅速锁定问题所在的具体组件。比如在界面调整的项目中,若发现显示异常,通过组件的检查,我们能迅速识别出是哪个组件未达标。

它能帮助开发者准确找到所需组件。这样就不会盲目搜索,造成时间上的浪费。特别是在页面布局复杂、组件众多的情况下,若没有这种检查功能,一个小小的显示问题可能需要几个小时才能找到原因。

frameworks/base/services/core/java/com/android/server/am/ActivityManagerService.javaprivate boolean attachApplicationLocked(@NonNull IApplicationThread thread, int pid, int callingUid, long startSeq) {    ....        try {                        int testMode = ApplicationThreadConstants.DEBUG_OFF;
// mDebugApp是命令后的入参,与之判断相等的是processName,而不是packageName if (mDebugApp != null && mDebugApp.equals(processName)) { testMode = mWaitForDebugger ? ApplicationThreadConstants.DEBUG_WAIT : ApplicationThreadConstants.DEBUG_ON;
// app是个ProcessRecord对象,这里将这个进程打上Debugging标记 app.setDebugging(true); if (mDebugTransient) { mDebugApp = mOrigDebugApp; mWaitForDebugger = mOrigWaitForDebugger; } }

....}

子进程断点调试困扰

当App拥有多个进程时,调试子进程的断点常常让人感到困扰。以前,手动添加和移除调试功能非常繁琐。在构建复杂的软件架构时,子进程数量众多,这种操作方法显得非常低效。

新的设置调试断点的子进程初始化方法非常高效。无需频繁手动操作,大大节省了时间。此外,这项技术能确保断点提前设置,不会遗漏重要的调试环节。

frameworks/base/services/core/java/com/android/server/am/ActivityManagerService.java public void setDebugApp(String packageName, boolean waitForDebugger,            boolean persistent) {        enforceCallingPermission(android.Manifest.permission.SET_DEBUG_APP,                \"setDebugApp()\");
final long ident = Binder.clearCallingIdentity(); try { // Note that this is not really thread safe if there are multiple // callers into it at the same time, but that\'s not a situation we // care about. if (persistent) { final ContentResolver resolver = mContext.getContentResolver(); Settings.Global.putString( resolver, Settings.Global.DEBUG_APP, packageName); Settings.Global.putInt( resolver, Settings.Global.WAIT_FOR_DEBUGGER, waitForDebugger ? 1 : 0); }
synchronized (this) { if (!persistent) { mOrigDebugApp = mDebugApp; mOrigWaitForDebugger = mWaitForDebugger; } mDebugApp = packageName; mWaitForDebugger = waitForDebugger; mDebugTransient = !persistent; if (packageName != null) { forceStopPackageLocked(packageName, -1, false, false, true, true, false, UserHandle.USER_ALL, \"set debug app\"); } } } finally { Binder.restoreCallingIdentity(ident); } }

set – debug – app的真相

这个set – debug – app命令的名称和说明似乎不太匹配。它最后的参数要求特定信息。只有查看源码才能理解其中的原因。如果输入了错误的信息,就无法为子进程开启调试功能。在不了解真相的情况下,可能会根据错误信息进行操作,这会导致浪费大量精力。

尽管拥有Shell权限,我们可以通过am set – debug – app来指定App的哪个进程进行调试,但AM并未提供开放接口。一般App无法直接调用那些未公开的系统API。我们需借助aidl的实现规则,模仿隐藏类创建同名同包的文件,以此解决编译难题。这些深藏不露的原理,我们需深入挖掘,才能明白如何在开发过程中正确使用。

frameworks/base/core/java/android/app/IActivityManager.aidl interface IActivityManager {    ....
void setDebugApp(in String packageName, boolean waitForDebugger, boolean persistent); ....}

在开发过程中,大家是否掌握了某些非常实用的技巧,或者遭遇过类似的问题?期待大家点赞、转发,并在评论区分享你的观点。

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

申明:本文由第三方发布,内容仅代表作者观点,与本网站无关。对本文以及其中全部或者部分内容的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。本网发布或转载文章出于传递更多信息之目的,并不意味着赞同其观点或证实其描述,也不代表本网对其真实性负责。

左子网 开发教程 不容错过的Android开发辅助工具App,提升效率必备神器 https://www.zuozi.net/78719.html

常见问题
  • 1、自动:拍下后,点击(下载)链接即可下载;2、手动:拍下后,联系卖家发放即可或者联系官方找开发者发货。
查看详情
  • 1、源码默认交易周期:手动发货商品为1-3天,并且用户付款金额将会进入平台担保直到交易完成或者3-7天即可发放,如遇纠纷无限期延长收款金额直至纠纷解决或者退款!;
查看详情
  • 1、描述:源码描述(含标题)与实际源码不一致的(例:货不对板); 2、演示:有演示站时,与实际源码小于95%一致的(但描述中有”不保证完全一样、有变化的可能性”类似显著声明的除外); 3、发货:不发货可无理由退款; 4、安装:免费提供安装服务的源码但卖家不履行的; 5、收费:价格虚标,额外收取其他费用的(但描述中有显著声明或双方交易前有商定的除外); 6、其他:如质量方面的硬性常规问题BUG等。 注:经核实符合上述任一,均支持退款,但卖家予以积极解决问题则除外。
查看详情
  • 1、左子会对双方交易的过程及交易商品的快照进行永久存档,以确保交易的真实、有效、安全! 2、左子无法对如“永久包更新”、“永久技术支持”等类似交易之后的商家承诺做担保,请买家自行鉴别; 3、在源码同时有网站演示与图片演示,且站演与图演不一致时,默认按图演作为纠纷评判依据(特别声明或有商定除外); 4、在没有”无任何正当退款依据”的前提下,商品写有”一旦售出,概不支持退款”等类似的声明,视为无效声明; 5、在未拍下前,双方在QQ上所商定的交易内容,亦可成为纠纷评判依据(商定与描述冲突时,商定为准); 6、因聊天记录可作为纠纷评判依据,故双方联系时,只与对方在左子上所留的QQ、手机号沟通,以防对方不承认自我承诺。 7、虽然交易产生纠纷的几率很小,但一定要保留如聊天记录、手机短信等这样的重要信息,以防产生纠纷时便于左子介入快速处理。
查看详情

相关文章

猜你喜欢
发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务