android 埋点实现方案 - 源代码篇

接上篇,看看部分源代码,没什么干货,已脱裤子的请绕路。

埋点记录类:Recorder.java

可以看到record方法,只是将埋点的存储动作(iLogCache.record)封装成 Runnable,然后通过持有的 Handler 对象 post 给 相应的 HandlerThread。HandlerThread 接受该消息后便执行该动作。

Recorder.java 职责分明,就只有record 方法,然后没了。

埋点发送类:Sender.java

可以看到 send方法,只是将埋点的发送动作(trySend 网络请求方法)封装成 Runnable,然后通过持有的 Handler 对象 post 给 相应的 HandlerThread。HandlerThread 接受该消息后便执行该动作。

这里加上了重试方法,发送失败会通过 Recorder对象再次存储起来,直至三次重试之后。

同样 Sender 也是职责分明,只负责发送 (send方法)。

埋点读取类:ReaderThread (线程)

埋点读取类只是简单的一直轮询数据缓存对象(ILogCache),当不为空的时候,通过埋点发送类(Sender)发送埋点。

最后,LogServiceV2.java

LogServiceV2 继承了Service。在init 方法里初始化了 Recorder,Sender,ReaderThread 这三个关键角色。

整个方案的源代码篇到此结束。

至于怎么用嘛,

startService,然后调用Recorder.record方法就可以了。实际项目里,也仅有LogServiceV2 与 Recorder 对外公开,而Recorder 更是一个单例,方便外层直接 getInstance().record()。

贴了代码,有没有清晰些呢,各位看官。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 第一次听到埋点这名词的时候,是在三年前,刚进某会时。 随后一直接触相关埋点需求的开发,然而,却一直没有好好的研究过...
    进击的杰爷阅读 5,702评论 2 7
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,131评论 19 139
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 174,081评论 25 709
  • java 接口的意义-百度 规范、扩展、回调 抽象类的意义-乐视 为其子类提供一个公共的类型封装子类中得重复内容定...
    交流电1582阅读 2,325评论 0 11
  • 身体一日不如一日,想想死亡和疾病正在向我靠近,还有那么多事还没做。
    皑弁阅读 267评论 0 1