美文网首页Android面试题Android 开发经验集面试
Android面试一天一题(Day 32:谈谈使用过的第三方开源

Android面试一天一题(Day 32:谈谈使用过的第三方开源

作者: goeasyway | 来源:发表于2016-12-27 22:14 被阅读6549次

    在大家多年的开发经历中,恐怕一定会被告知过这句话:“不要重复造轮子 ”。如果网上已有现成的解决方案或者开源库,大多数时候并不建议重新开发。如果你经常爱在网上搜索,你可能会发现,其实大多数你要实现的功能都已经有人实现过并开源了,没找到只是你不太会用搜索引擎而已。

    在Android开发中,有很多优秀的“轮子”可供开发人员选择,那么怎么选怎么用就是问题了,所以在面试中我很喜欢问这种在使用第三方开源库时遇到的问题。

    面试题:谈谈你使用过的Android开源库,是否有遇到过什么问题?

    前段时间和京东的一位Android工程师在聊使用第三方库的问题,他也喜欢问面试者在使用第三方库时有遇到什么问题和解决的方案,他给我举了个关于网络请求库OKHttp的例子(OKHttp这个开源框架处理请求转发时会有问题)。如果对方在网络开发上很有经验,比如像他们做电商移动应用的,是很容易遇到这样的问题。

    前几年在一个项目中,我有使用EventBus事件总线框架做为应用UI和逻辑沟通的桥梁,后来也发现并不像我想象中的好用。太多的消息事件会让代码的可读性和可维护性降低,当时EventBus还使用反射的方式实现,性能上也有一定的消耗(EventBus升级3.0以后事件的订阅已经从方法名换成了注解的方式)。

    EventBus是一款针对Android优化的发布/订阅事件总线(内部是观察者设计模式)。主要功能是替代Intent,Handler,BroadCast在Fragment,Activity,Service,线程之间传递消息.优点是开销小,代码更优雅。以及将发送者和接收者解耦。

    当然,�每个人遇到的问题都不一样,有些别人用着很正常的开源库你用着就可能会出问题。比如我遇到的Glide图片加载库在初始化Glide实例时写死了Context的问题,在一般的应用中这样做并不会出现问题,但在插件框架上就会因为这个Context被写死就会导致插件资源错乱的问题。

    Glide.with(this).load("http://goo.gl/gEgYUd").into(imageView);
    

    Glide在初始化时记录了一个Context做为其内部使用,之后虽然每次都会通过“with(this)”传入一个Context,但这个新的Context却不会被使用。

    还有一些项目中使用ORM(对象关系映射)的数据库框架,如AFinal、GreenDao,有些框架在多线程操作数据时会锁住整个表(在ORM的概念里,其实就是Dao类),导致在初始化时因为子线程在锁住某个类阻塞了UI线程的数据表操作。

    如果没有问题呢?

    可不可以在使用第三方开源库时,就是没有问题呢?当然可以,不过你可以聊一聊你为什么要选择这个库,其实就是从侧面来说明:你对这个库的优缺点的看法,以及你是否了解它的实现原理,因为你要对自己的项目负责(开源作者可不需要)。

    小结

    这里举了几个小例子,还有很多优秀的开源框架。其实很多程序员的问题是很少使用开源库或者框架,除了图片加载库是必备之外,其他的开源库很多人就不一定会使用了,自然也不会遇到什么问题。

    为什么我会比较看重这一点呢?因为,我觉得第三方的开源库,你不一定要在自己的项目中使用,但你一定要去学习别人是怎么写这个库的,是不是比你的方法更好,而且很多流行的开源库都是一些Android大牛写的,直接读和修改他们的代码是你接近他们最简单的方式。

    相关文章

      网友评论

      • Eric_feng:“导致在初始化时因为子线程在锁住某个类阻塞了UI线程的数据表操作。”这个具体是什么意思,什么初始化,怎么又阻塞了UI线程对数据表的操作,数据表操作不都是在子线程执行吗?
      • 67798e788591:接近大牛的捷径,精辟!
      • Coralline_xss:楼主,你好,自从关注你后,就一直在看你发的文章,此时看到这篇,心中一直有个疑问,就是我不知道怎么才算完全弄懂一个框架?我现在研究一个框架先学基础怎么用,再按流程看源码并输出流程图,过一遍脑海中有一个完整的流程就打住了,目前因我比较记着找工作,也只能用如此方式,就是不知道面试遇到这样的问题能否应付地了。
        Coralline_xss: @goeasyway 多谢楼主提醒了一下,我好似很少从框架的优缺点去学习以及这个优缺点是如何体现在源码中的
        goeasyway:@Coralline_xss 很多时候也是基于工作需要或者自己的兴趣才会去弄懂一个开源框架的代码和架构。基于使用的话,确实不需要特别深入,能像你一样画个流程图,理一个大概,知道它的一些缺陷和优点其实就很不错了。不过熟悉了一两个框架后,如果有意识提高自己的话,往往会考虑自己能不能写了这样的框架,它倒底是怎么做到的,自己去实现会怎么做。如果没时间的话,可以先回忆一些平时使用这些框架遇到的问题及你的解决方法,如果完全没有问题,那就要对应不同的问题来和面试官交流了,其实也可以分享一些自己对它的看法或改进想法。
      • e50a04679272:你好,请问一下“OKHttp这个开源框架处理请求转发时会有问题”,能稍微具体一点说一下吗?最近要用这个框架,但网上好像没找到相关信息,万分感谢
      • 阿姆斯特狸:楼主 写的一如既往的好啊!但是 希望楼主能把解决方案写的详细一点 多举一些例子 关键在于怎么解决问题 能给大家做个参考!
        goeasyway:@阿姆斯特狸 收到:stuck_out_tongue_winking_eye:

      本文标题:Android面试一天一题(Day 32:谈谈使用过的第三方开源

      本文链接:https://www.haomeiwen.com/subject/gupevttx.html