写点什么

揭秘《阿里巴巴 Android 开发手册》

  • 2018-04-03
  • 本文字数:2312 字

    阅读完需:约 8 分钟

前言

不久之前谷歌的 Android P 预览版问世,几大手机厂商也联合推出了快应用,我们看到了移动开发迎来了新的活力,移动应用已经渗透到人们生活的方方面面,那么阿里继去年推出 Java 手册之后,在春节期间推出的《阿里巴巴 Android 开发手册》的目的是什么呢?为此,InfoQ 第一时间采访了阿里巴巴高级无线开发工程师、手册的主要作者之一芸墨,为大家揭开其背后创作故事,并在此与大家分享采访结果。

Android 开发手册有哪些内容?

《阿里巴巴 Android 开发手册》全篇分为 9 个章节,分别是 Java 语言规范,Android 资源文件命名与使用,Android 基本组件,UI 与布局,进程、线程与消息通信,文件与数据库,Bitmap、Drawable 与动画,安全及其他内容,即主要涵盖了 Android 开发的性能、安全性和稳定性问题。作者认为这些章节不分主次,都是开发者在进行业务开发时容易忽视的问题,大家可根据实际情况参考。

Android 开发手册是怎样诞生的?

阿里做这件事的初衷源于双十一,由于每年在双十一准备期间都要成立专家组去集中扫荡线上 crash,把 crash 率降到 0.1% 以下,修复 bug 以后,可能在不久的将来又会重现,那如何把专家的经验沉淀下来得以复用呢?

在这些过程中,他们把一些常见 crash 的分析沉淀了下来,把一些结合 codestyle 写到了阿里 Android 开发手册里,还有一些写成了自定义规则放到了持续集成平台和 IDEA 插件里,比如常见的 CursorWindowAllocationException、SuperNotCalledException 和 ConcurrentModificationException 这一类的问题。后来他们想把这些好的经验开放出来跟大家一起分享,所以《阿里巴巴 Android 开发手册》就面世了。

然而手册发布之后,在引起高关注度的同时,也引发了不少读者的质疑,很多人认为阿里在技术分享上动作频频,连发两个手册,是否是内部 KPI 推动的结果。对此,芸墨表示这并不是 KPI 任务,各研发团队的主管并没有给大家硬性指标,手册的编者都是集团各大 APP 的一线业务开发者,来自淘宝、天猫、闲鱼和支付宝等团队,他们都是自发地组成一个虚拟项目组,本着前人栽树后人乘凉,前人踩坑后人平路的心态,总结日常中解决的诸如性能、稳定性、安全、UI 适配等问题的经验,并在日常的业务工作之余完成了手册的内容。

三个等级划分的标准是什么?

不管是之前 Java 手册还是现在的 Android 手册,阿里都按照约束力强弱将规则划分了强制、推荐、参考三个等级,对于这几个等级的制定,芸墨是这么解释的:

(1)把会造成线上稳定性问题、严重的性能问题和展示问题,常见的安全问题的写法定义为【强制】级别的。

(2)把一些阿里的最佳实践和一些经验沉淀定义为【推荐】级别的,比如很多开发者最近都在问的“文本大小使用单位 dp 这一条是不是有问题,难道不是应该用 sp 吗?”

实际上,在 App 在开发时,视觉都是设计好了整体 UI 布局和控件的尺寸、位置,根据操作系统字体大小设置动态调整 app 字体会造成开发成本高到不可承受。在 Android 上,很多 App 对文本采用了 sp 作为单位,事实上就造成了它们的 UI 在字体大小变化的情况下完全无力适配,内容显示异常。所以,约定的时候就考虑到了现实情况。如果一个产品在设计的时候就已经考虑到对字体设置的需求,那是可以无视这一条;只是大部分的 app 在设计的时候视觉交互其实只有一套,对他们来说的话如果忽略了这个问题用 sp 就会造成 UI 显示的缺陷。

(3)把一些阿里内部各个团队自己的约定定义为【参考】,即大家可以自行决定是否使用。

如果规范与需求发生冲突,该如何应对?

一般说来,产品经理需要保证自己需求的还原性和整体体验,开发者也希望自己写出的代码美观整洁 bug 少,大家都是同一战线的伙伴,但是手册中明令禁止的行为可能会对产品的可用性造成很严重的影响,会影响产品的线上使用,所以芸墨并不赞成开发者违背规范中强制的内容,而对于推荐和参考的内容,只要不影响产品的用户体验,开发者择优选择即可。

Android 手册面向哪些开发者?

虽然手册面向的主要是 Android 开发者,非 Native 的开发者如果指纯 H5 的开发者那可能跟规约并没有直接联系,如果指的是 RN 这种新兴的动态化框架的话,那么规约在性能优化、安全等方面依旧是可以为他们提供开发上的参考。

再者,芸墨认为,无论是 H5、RN、微信小程序的开发,还是 IOS/Android 原生开发,在 UI framework 这个层面原理是相通的,并不是新技术新框架出现了,已有的框架就被完全推倒重来。其次,RN、微信小程序越来越受关注是因为他们体现出来的组件化、动态化、快速部署的能力对原生开发者产生了巨大的吸引力,但是在这个过程中,JavaScript 扮演的更多的是一种 DSL(domain specific language)的角色,而不是说一看到 JavaScript 就等同于前端开发,他们本质上还是运行在原生操作系统上的,所以 Android 手册里的内容对那些学习新框架的 Android 原生开发者仍是不可或缺的基础。

关于未来

对于 Android 手册,阿里会时刻关注和及时回复线上的用户反馈,前期保持一个月一版本的迭代速度,中后期会根据 Android 的系统更新情况半年一次迭代,并表示 iOS 开发手册内部版本正在筹划对外开放中,敬请期待~

Android 手册的内容都是阿里集团业务开发者的经验总结,也结合了 Google 和业界的一些最佳实践,去年已经在集团内部公示过很久,也得到了广泛的认可。一个行业标准手册出之不易,阿里表示他们会秉持着开放的态度,欢迎业内同行一起参与意见反馈和完善工作,这是他们愿意见到的行业幸事。

手册下载链接

http://click.aliyun.com/m/44351/

受访嘉宾简介

龚能(花名:芸墨)阿里巴巴高级无线开发工程师,2014 年入职阿里巴巴,主要负责集团无线静态代码扫描体系建设和持续集成平台开发,《阿里巴巴 Android 开发手册》的主要作者之一。

2018-04-03 18:145462
用户头像

发布了 83 篇内容, 共 48.5 次阅读, 收获喜欢 187 次。

关注

评论

发布
暂无评论
发现更多内容

跨平台的Markdown编辑器:Typora for Mac中文版

真大的脸盆

今年互联网是“银二铜三铁四丐五”?程序员面试如何破局?

Java你猿哥

Java 架构 算法 多线程 java面试

还在分不清各种IO模型?

Java你猿哥

Java Linux io I/O模型 Java IO

头部企业走入无人区,国产数智化厂商挑大梁

用友BIP

兼顾可扩展、高并发与数据一致性:咸鱼优惠系统设计实践

Java你猿哥

Java 架构 ssm 架构设计 并发

SpringBoot 结合 Liquibase 实现数据库变更管理

做梦都在改BUG

Java spring Liquibase

2023淘宝天猫金婴奖公布,小度学习机获年度超级新品奖!

科技热闻

大模型竞争白热化 这家广州的科技公司却开辟了新战场

科技热闻

德邦快递:逆境之下,让数字化辅助业务的利润增长

Kyligence

数据分析 数字化管理 指标中台

WebSocket与Socket、TCP、HTTP的区别

Apifox

程序员 TCP socket HTTP websocket

全新问世!阿里内藏版的SpringBoot 2.5实战笔记,全面覆盖新特性

做梦都在改BUG

Java spring 微服务 Spring Boot 框架

Spring Boot如何优雅提高接口数据安全性

做梦都在改BUG

Java spring Spring Boot

MySQL百万数据深度分页优化思路分析

做梦都在改BUG

Java MySQL 数据库

共识算法之Raft算法模拟数

TiAmo

算法 共识算法 模拟数

如何解决注册并发问题并提高QPS

北桥苏

队列 并发 Redis 核心技术与实战

哪些技术有可能坐上智慧城市发展的快车

Onegun

智慧城市 小程序容器 数字城市

【活动报名】PolarDB开源数据库&PG中文社区技术沙龙温州站

阿里云数据库开源

数据库 postgresql 阿里云 开源 polarDB

MLCC龙头涨价;车厂砍单芯片;台积电28nm设备订单全部取消!

元器件秋姐

芯片 汽车 资讯 新能源 MLCC

做客《创新之路》,Tapdata 创始人唐建法对话央视著名主持人李雨霏,畅聊创业故事

tapdata

百人研发团队百亿销售规模的技术架构实践分享

车江毅

intellij idea 粘贴字符串如何不带换行符?

源字节1号

微信小程序 开源 软件开发 前端开发 后端开发

GitHub发布即百万!字节内网超实用 java性能优化手册,star超十万

Java你猿哥

Java JVM ssm Java性能调优 java程序优化

Last Week in Milvus

Zilliz

Milvus Zilliz 向量数据库

GPT:低代码的终局性机遇

小博

人工智能 低代码 PaaS GPT

重磅来袭!豆瓣评分9.2,万人血书的多线程与高并发v2.0版本

做梦都在改BUG

Java 多线程 高并发

从GitHub火到头条!共计1658页的Java岗面试核心MCA版,拿走不谢

做梦都在改BUG

Java java面试 Java八股文 Java面试题 Java面试八股文

大开眼界!Jenkins结合SpringCloud+K8S,打通微服一条龙技术讲解

做梦都在改BUG

Java Kubernetes k8s Spring Cloud jenkins

如何更好的分析潜在人脉?聊聊华为云图引擎GES的Cypher子查询

华为云开发者联盟

人工智能 华为云 华为云开发者联盟 企业号 5 月 PK 榜

创业做共享电动车!如何找厂家合作

共享电单车厂家

共享电动车厂家 共享电单车厂商 共享电单车投放 共享电动车创业项目

小程序的安全架构解析

Onegun

小程序 安全 小程序容器 小程序架构

阿里内部教材:15W字的SpringCloud微服务实战,我一口气给你打包

做梦都在改BUG

Java 架构 微服务 Spring Cloud

揭秘《阿里巴巴Android开发手册》_Android/iOS_覃云_InfoQ精选文章