当前位置:网站首页 > 编程语言 > 正文

kodi插件库换国内源(kodi19 插件库)



最近在升级 Android 项目里的阿里云播放器 SDK 版本,其中很多相关逻辑是基于阿里云提供的 Demo 来更新的。修改完自测时,发现下载器的回调接口偶现不回调的问题。本文简要记录解决过程。

首先来看有问题的代码,Demo 里下载相关的有这么一段:

 
  

调用这个方法后,正常情况下 onPrepared 和 onError 必被调用到其一,但现实是偶尔会出现两个都没被回调的情况。

那种感觉就像,你约好了朋友一起吃饭,结果他突然失联了,打电话不接,发消息不回,然后你就一个人在那里等着。这种事情在生活里不能忍,在代码里能忍?

通过一番艰苦的排查,久久没有思路,只好闷闷不乐地下班回家了。晚上洗澡的时候,突然想到,会不会是 downloader 被 GC 了?赶紧拿小本本记下思路,第二天一早翻出这块代码一看,果然如此。

downloader 是在方法内部创建的局部变量,方法执行完毕后,downloader 就会被释放,如果此时发生 GC,就会回收它对应的对象。到了回调时机,发现 downloader 对应的对象已经被回收了,回调也就无从谈起了

那要打破这个局面,就需要将 downloader 的引用保持住,在必要的回调发生以后再释放。比如我们可以想到,这段代码所在类是一个单例,那么在它里面声明一个 List,将 downloader 放进去,等回调结束后再移除。这样就能保证 downloader 在回调发生时还没有被回收。

修改后的代码类似这样:

 
  

在尝试做以上修改时,发现了一个 彩蛋

阿里云的官方 Demo 里,其实已经声明了 mJniDownloadLists,且有注释 ,并且在其它类型的 prepareDownload 里也做了类似的处理,但不知道为什么在 VidAuth 类型参数的 prepareDownload 里没有,可能是漏掉了。

在 Android / Java 项目里,类似的场景应该并不少见。虽然 GC 带来了很多便利,但在实际编码时,我们也需要注意对象的生命周期管理,该存活的存活,该释放的释放,避免因为 GC 导致的问题。


如果读完文章有收获,可以关注我的微信公众号「闷骚的程序员」并🌟设为星标🌟,随时阅读更多内容。

到此这篇kodi插件库换国内源(kodi19 插件库)的文章就介绍到这了,更多相关内容请继续浏览下面的相关推荐文章,希望大家都能在编程的领域有一番成就!

版权声明


相关文章:

  • 结构游戏的分类及技巧有哪些(结构游戏的分类及技巧有哪些方面)2026-04-22 10:18:08
  • 重绘是什么意思啊(重绘是什么意思啊怎么读)2026-04-22 10:18:08
  • ewm焊机报警代码(dm350焊机报警e800)2026-04-22 10:18:08
  • 社会阶级分层图表(社会阶层划分标准有哪些)2026-04-22 10:18:08
  • 有网页版的聊天工具(现在还有网页版聊天室吗)2026-04-22 10:18:08
  • 制作启动盘的u盘(制作启动盘的u盘为什么下载不了歌曲)2026-04-22 10:18:08
  • 社会阶级分层图(中国社会阶级分层图)2026-04-22 10:18:08
  • 对乙酰氨基酚片联合用药(对乙酰氨基酚片联合用药有哪些)2026-04-22 10:18:08
  • 拒绝你访问该文件夹u盘(拒绝你访问该文件夹win10)2026-04-22 10:18:08
  • 高血压危险分层图片(高血压危险分层表图片)2026-04-22 10:18:08
  • 全屏图片