技术纵横
1)从分层复用到自动化测试,看美团客户端架构的演变
伴随着业务的飞速发展,美团点评的客户端研发团队的规模从初期的 20 余人的发展为数百人,且分散在不同的业务团队。拥有如此大规模的研发团队,他们是如何保证高效的内外部协同效率?美团与大众点评原本是两家独立运营的大型互联网公司,分别有着不同的积累和储备。两家的合并为业务带来巨大的好处的同时也为技术团队带来了巨大的挑战——如何能够同时高效地在美团和大众点评两个 App 上实施业务开发?
2)人工智能反欺诈三部曲之:设备指纹
在移动互联网日益成为主流的今天,身份欺诈成为在线欺诈的顽疾,欺诈者以移动设备为掩体发动攻击。以设备指纹为核心的设备风险识别相关技术是刺破欺诈者身份伪装的利器。本文针对设备指纹分别从技术的缘起、流派、工作原理、核心技术难点和评估方法五个方面进行了剖析,希望能够帮助读者更深入的了解设备指纹技术,从而在反欺诈、风险控制等各环节中更好地利用这项技术。
3)聊聊移动端跨平台开发的各种技术
百度FEX开发人员对目前跨平台开发技术流派的一个调研总结,值得学习一下
Android 开发
1)今日头条屏幕适配方案终极版正式发布!
今日头条适配方案 和SmallestWidth 限定符适配方案,这两个方案中,并不能以单个标准就能评判出谁一定比谁好,因为它们都有各自的优缺点,都不是完美的,从更客观的角度来看,它们谁都不能成为最好的那个,只有可能明确了它们各自的优缺点,知道在它们的优缺点里什么是我能接受的,什么是我不能接受的,是否能为了某些优点做出某些妥协,从而选择出一个最适合自己项目的屏幕适配方案。
2)在Java中如何优雅地判空
作为搬砖党的一族们,我们对判空一定再熟悉不过了,不要跟我说你很少进行判空,除非你喜欢NullPointerException。
3)图解 View 测量、布局及绘制原理
Android中自定义View一直是一个高级的技能,入门比较难,看起来很高大上。想要学会自定义View,当然要理解View的测量、布局及绘制原理,本篇文章将以图表的形式讲解View的测量、布局及绘制原理。
4)Android 最全面的Webview详解
现在很多App里都内置了Web网页(Hyprid App),比如说很多电商平台,淘宝、京东、聚划算等等。这种该如何实现呢?其实这是Android里一个叫WebView的组件实现的。今天我将全面介绍WebView的常用用法
5)如何设计一个优雅健壮的android webview(上)
Android应用层的开发有几大模块,其中WebView是最重要的模块之一。网上能够搜索到的WebView资料可谓寥寥,Github上的开源项目也不是很多,更别提有一个现成封装好的WebView容器直接用于生产环境了。本文仅当记录在使用WebView实现业务需求时所踩下的一些坑,并提供一些解决思路,避免遇到相同问题的朋友再次踩坑。
iOS 开发
1)Objective-C 拾遗:从Heap and Stack到Block
语言基础知识的再探索。
2)fishhook源代码解析
在做网络性能监听的时候,需要对网络状态进行监听,OC的代码可以通过runtime机制做hook,但是其中涉及到C代码函数,如何进行hook?通过查资料,使用fishhook可以解决这个问题。
3)深入浅出 iOS 并发编程
iOS 开发中,并发编程主要用于提升 App 的运行性能,保证App实时响应用户的操作。主线程一般用于负责 UI 相关操作,如绘制图层、布局、交互相应。很多 UIKit 相关的控件如果不在主线程操作,会产生未知效果。Xcode 中的 Main Thread Checker 可以将相关问题检测出来并报错。
4)对于 iOS 开发,人工智能意味着什么?
近几年来人工智能的话题那是炙手可热。在国内很多大佬言必谈机器学习和大数据;在美国刚毕业的人工智能 PHD 也是众人追捧,工资直逼 NFL 四分卫。人工智能甚至成为了互联网领域茶余饭后的话题 —— 仿佛不懂人工智能就是落伍了。
5)iOS 事件传递与响应机制原理
按照时间顺序,事件的生命周期是这样的: 事件的产生和传递(事件如何从父控件传递到子控件并寻找到最合适的view、寻找最合适的view的底层实现、拦截事件的处理)->找到最合适的view后事件的处理(touches方法的重写,也就是事件的响应)
其中重点和难点是: 1.如何寻找最合适的view 2.寻找最合适的view的底层实现(hitTest:withEvent:底层实现)
6)iOS图形性能进阶与测试
这篇文章主要是学习完Advanced Graphics and Animations for iOS Apps这个session后的总结和相应细节的延伸和细化。主要内容为图形性能与测试工具两个章节。
React Native
1)糯米React Native组件化框架方案
随着糯米在生活服务O2O平台化战略上的转型,大量的自营/第三方垂类业务需要快速接入糯米,对糯米移动App端的架构提出了挑战。在这样的背景下,我们在2015年初开始对糯米App端架构进行组件化改造。
糯米将垂类业务抽象成为组件,组件之间解耦。通过Hybrid方案(web开发方式+桥接native能力),打通Web和Native能力,解耦业务代码,实现跨平台开发。糯米将业务所需的所有静态资源打包成一个组件包文件,进行离线化版本管理,实现了组件业务的动态更新。
前端开发
1)认识和使用promise
一直以来,JavaScript处理异步都是以callback的方式,在前端开发领域callback机制几乎深入人心。在设计API的时候,不管是浏览器厂商还是SDK开发商亦或是各种类库的作者,基本上都已经遵循着callback的套路。近几年随着JavaScript开发模式的逐渐成熟,CommonJS规范顺势而生,其中就包括提出了Promise规范,Promise完全改变了js异步编程的写法,让异步编程变得十分的易于理解。今天我们就来了解一下Promise~~
2)IMWeb 2018 IMWeb论坛 IMWeb 2018会议资料(提取码: xgjf)
IMweb是腾讯前端团队,组织了IMWeb Conf会议,分享了论坛等学习资料。