当前位置: 首页 > news >正文

东莞市疾控中心24小时咨询电话家庭优化大师免费下载

东莞市疾控中心24小时咨询电话,家庭优化大师免费下载,it培训机构哪家强,注册代办工商公司S905L3 带有投屏的功能,并通过 com.droidlogic.mediacenter.dlna.MediaCenterService 服务的启动和停止来开启和关闭DLNA功能,但是在测试中发现机顶盒关闭DLNA后,手机还能搜索到盒子。我在复测中发现关闭后有时很难很久搜索到盒子&#xff0c…

        S905L3 带有投屏的功能,并通过 com.droidlogic.mediacenter.dlna.MediaCenterService 服务的启动和停止来开启和关闭DLNA功能,但是在测试中发现机顶盒关闭DLNA后,手机还能搜索到盒子。我在复测中发现关闭后有时很难很久搜索到盒子,有时却很容易搜索到。

        通过查看日志,发现打开和关闭盒子,com.droidlogic.mediacenter进程分别只有一条日志,线索有限。

行  266: 05-31 09:35:54.089  4603  4603 D WeakRefService: net.droidlogic.action.dlna   state:true
行 1171: 05-31 09:36:04.272  4603  4603 D WeakRefService: net.droidlogic.action.dlna   state:false

        调试了盒子设置界面打开和关闭DLNA的流程,大概已经熟悉,但是没有找出关闭的流程有什么问题,设置APP的逻辑比较简单,接口jar包dlna.jar则代码较多,不太容易完全掌握其逻辑。难于定位是设置APP调用有问题还是调用的接口本身有问题。但是我想,虽然不知道关闭DLNA需要调用什么代码和接口,而且关闭会失败,很难定位关闭的正确流程。但是可以通过定位开机打开DLNA调用了什么接口,从而能猜测到关闭DLNA需要什么接口。

        于是开机后打开DLNA, 一路的设置断点,且每个断点都在手机上确认能否搜到盒子,最后在adv.start()执行后,手机就能搜到盒子了。

    public boolean start() {Debug.d("DEVICE", "========httpServerList.start");int retryCnt = 0;int bindPort = this.getHTTPPort();HTTPServerList httpServerList;for(httpServerList = this.getHTTPServerList(); !httpServerList.open(bindPort); bindPort = this.getHTTPPort()) {++retryCnt;if (100 < retryCnt) {return false;}this.setHTTPPort(bindPort + 1);}httpServerList.addRequestListener(this);httpServerList.start();Advertiser adv = new Advertiser(this);this.setAdvertiser(adv);adv.start();Debug.d("DEVICE", "========SSDPSearchSocketList.start");if (HostInterface.getAvailNet() != null && HostInterface.getAvailNet().length > 0) {this.setSSDPBindAddress(HostInterface.getAvailNet());}SSDPSearchSocketList ssdpSearchSockList = this.getSSDPSearchSocketList();if (!ssdpSearchSockList.open()) {return false;} else {ssdpSearchSockList.addSearchListener(this);ssdpSearchSockList.start();this.peers.clear();return true;}}

       Advertiser继承线程类,start后整个线程就跑起来了。他的逻辑还是很清楚,先调用byebye,如果线程关联的设备跟其他设备绑定了,先解绑(花5秒钟),然后对外广播,设备激活了,之后每隔320秒广播一次。在这个类里面也能容易发现关闭DLNA要调用stopAdvertiser,再设置断点,发现调用stopAdvertiser后,这个线程停止不下来,于是还是会320秒广播一次。

public class Advertiser extends Thread
{private static Thread advertise;private Device device;public Advertiser(final Device dev) {this.setDevice(dev);}public void setDevice(final Device dev) {this.device = dev;}public Device getDevice() {return this.device;}public void stopAdvertiser() {if (Advertiser.advertise != null) {final Thread tmpThread = Advertiser.advertise;tmpThread.interrupt();Advertiser.advertise = null;}}@Overridepublic void run() {Advertiser.advertise = Thread.currentThread();this.getDevice().byebye();try {Thread.sleep(5000L);}catch (InterruptedException e) {e.printStackTrace();while (true) {this.getDevice().announce();try {Thread.sleep(320000L);}catch (InterruptedException ex) {break;}}}finally {while (true) {this.getDevice().announce();try {Thread.sleep(320000L);}catch (InterruptedException ex2) {}}}}static {Advertiser.advertise = null;}
}

      在这里就可以发现问题的所在,当调用stopAdvertiser出发线程中断时,run 循环对InterruptedException 异常没有做任何处理,所以也不会停止,可以考虑捕获异常时,跳出循环。但是dlna.jar没有源码,只有jar包,因此要做反编译处理。

      找到S905L3的编译环境,查看是用的jdk 8,  把该jdk加入到环境变量 PATH。

      生成class文件,把dlna.jar拖入eclipse 或者 android studio, 找到相应的类,可以直接看到代码,然后把代码复制到一个空的Advertiser.java文件上,修改对应的逻辑。然后用命令: javac Advertiser.java, 生成新的Advertiser.class

      第一次修改只在抛异常处增加break语句,但是编译后发现break语句会被优化掉,第二次修改把捕获中断异常放到循环外,问题得到解决。

        //修改前try {Thread.sleep(5000L);}catch (InterruptedException e) {e.printStackTrace();while (true) {this.getDevice().announce();try {Thread.sleep(320000L);}catch (InterruptedException ex) {}}}//第一次修改try {Thread.sleep(5000L);}catch (InterruptedException e) {e.printStackTrace();while (true) {this.getDevice().announce();try {Thread.sleep(320000L);}catch (InterruptedException ex) { break;}}}//第二次修改try {Thread.sleep(5000L);while (true) {this.getDevice().announce();Thread.sleep(320000L);}}catch (InterruptedException e) {e.printStackTrace();}

      解包:unzip dlna.jar

      打包:把新的Advertiser.class替换到解包出来的文件夹, 用下命令打包:jar -uvf dlna.jar org/cybergarage/upnp/device/Advertiser.class。dlna.jar就由旧的dlna.jar变成了新的dlna.jar。

      用新的dlna.jar编译设置APK,通过自测和测试复测,问题没有再出现。

     

http://www.ds6.com.cn/news/41561.html

相关文章:

  • 网站建设好的公司搜索引擎大全网站
  • 工程建设流程seo数据优化教程
  • 网站开发专业就业前景分析seo还可以做哪些推广
  • 网站上传文件功能实现计算机培训
  • 建e室内设计装修效果图什么是淘宝seo
  • 用ps怎么做网站步骤软件推广怎么赚钱
  • cms网站建设系统windows优化大师兑换码
  • wordpress小程序改造在线排名优化工具
  • 网站关键词优化有用吗免费顶级域名注册网站
  • 网站建设需求模版万词优化
  • 安徽建设工程安全监督总站网站宁波seo关键词
  • 专业网站建设全包查网站
  • 现在流行什么做网站seo文章排名优化
  • 做印刷品去哪个网站软文推广发布平台
  • 做博客网站什么空间好软文网站有哪些
  • 海城网站制作建设上海高玩seo
  • 电子工程王北辰windows优化大师怎么使用
  • 张家界官方网站关键词优化按天计费
  • 网站建设seo视频百度seo快速排名优化软件
  • 网站设计与wap网站开发技术3322免费域名注册
  • 网站如何快速备案百度商业平台
  • 网站建设 cms上线了建站
  • 如何网站里做照片网络软文范例
  • 关于做美食的小视频网站佛山网站优化
  • 烟台专门做网站的广告平台
  • 网站建设管理调研提纲楼市最新消息
  • 盐城网站建设24gx驻马店百度seo
  • 购物网站中加减数目的怎么做活动推广文案
  • 电商网站建设毕业设计安卓优化大师hd
  • 建行官网官网网站吗打开浏览器直接进入网站