通过logcat学习android上层任一一个功能的流程

这几天,客户想在android系统中加入Multicast功能,这个功能在kenerl层,我通过make menuconfig找到了驱动位置。但客户还有一个需求,就是同时enable 以太网和wifi功能,通常android的framework层不允许同时打开这两个选项。因为如果你上网,只需要其中一个network被激活就行。但是客户想用wifi接internet,用ethernet作为multicast服务端,即ehternet不是用作接收数据,而是发送数据。所以,要想办法找到相关代码。


芯片原厂给我们的一个建议是,从app源代码去看,看怎么调用的,然后屏蔽相关代码。我循着这个思路,发现只能在app层打转,因为很多代码都封装在framework层的manager和service函数中。上层只看到调用和UI的设置。

结果,我的同事说用串口去看信息,然后他转念一想,串口只看到底层的流程,所以要用adb logcat一想。我突然被启发到,这个办法好,作弊阿。一直都以为要看代码才能了解一个模块的功能和调用层次,没想过可以用调试手段去学习一个模块。这样,同事通过logcat迅速找到了相关代码在ConnectivityService.java.因为在开启ethernet功能时,logcat提示了这个模块被打开,并在下一个信息中提示,wifi被teardown。

于是,在那个java文件中,同事找到了teardown函数和相关的控制逻辑。这样,通过调试工具logcat,我们知道怎么改控制逻辑,实现我们的目标需求。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值