任正非公开信:投入20亿美元全面提升华为软件质量

任正非:全面提升软件工程能力与实践,打造可信的高质量产品

2019 年 1 月 03 日

任正非公开信:投入20亿美元全面提升华为软件质量

昨天,华为心声社区发布了来自任正非的公开信《全面提升软件工程能力与实践,打造可信的高质量产品》,信中强调从基础代码做起,全面提升华为软件工程能力和实践,其中提到一些重要举措,包括编码质量、架构设计、重构、安全、流程和考核等。


以下为正文:


致全体员工的一封信:

我今天写信,是要和大家沟通公司如何全面提升软件工程能力和实践。

二十年前的IPD变革,重构了我们的研发模式,实现了从依赖个人、偶然性推出成功产品,到制度化、持续地推出高质量产品的转变。至今为止,我们的产品和解决方案已经在170多个国家安全稳定运行,并因此积累和赢得了全球数万客户的信任。

今天,我们又处在一个新的起点,全面云化、智能化、软件定义一切等发展趋势,对ICT基础设施产品的可信提出了前所未有的要求。可信将成为客户愿买、敢买和政府接受、信任华为的基本条件。可信不仅仅是产品外在表现的高质量结果,更是产品内在实现的高质量过程,是结果和过程的双重可验证的高质量。而只有全面提升软件工程能力和实践,才有可能打造出可信的高质量产品。

公司已经明确,把网络安全和隐私保护作为公司的最高纲领。我们要在每一个ICT基础设施产品和解决方案中,都融入信任、构建高质量,关键内容包括:

安全性(Security)。产品有良好的抗攻击能力,保护业务和数据的机密性、完整性和可用性。

韧性(Resilience)。系统受攻击时保持有定义的运行状态,包括降级,以及遭遇攻击时快速恢复的能力。

隐私性(Privacy)。遵从隐私保护既是法律法规的要求,也是价值观的体现。用户应该能够适当地控制他们的数据的使用方式。信息的使用政策应该是对用户透明的。用户应该根据自己的需要来控制何时接收以及是否接收信息。用户的隐私数据要有完善的保护能力和机制。

可靠性和可用性(Reliability& Availability)。产品能在生命周期内长期保障业务无故障运行,具备快速恢复和自我管理的能力,提供可预期的、一致的服务。

全面提升软件工程能力和实践,关乎公司未来的生存和发展,与我们每一个人都息息相关。在此,我希望全体员工、特别是软件工程师们主动参与进来,从自己做起,踏踏实实,共同打造可信的高质量产品。

我们要转变观念,追求打造可信的高质量产品,不仅仅是功能、特性的高质量,也包括产品开发到交付过程的高质量。我们知道,功能、特性对产品至关重要,我们更知道,进度对满足客户需求也至关重要。今天,我们要把可信作为第一优先级,放在功能、特性和进度之上。除非客户信任我们的产品,否则这些优秀的特性都没有机会发挥价值。我们各级管理者和全体员工都不得以进度、功能、特性等为理由来降低可信的要求,确保可信的要求在执行过程中不变形。

我们要从最基础的编码质量做起,视高质量代码为尊严和个人声誉。代码就像是高楼大厦的一砖一瓦,没有高质量的代码,可信的产品就是空中楼阁。我们要优化并遵循公司各种编程规范,遵从架构与设计原则,熟练使用各种编程库和API,编写出简洁、规范、可读性强、健壮安全的代码。

我们要深刻理解架构的核心要素,基于可信导向来进行架构与设计。在确保可信的前提下,要在性能、功能、扩展性等方面做好权衡;慎重地定义我们的模块与接口,真正做到高内聚与低耦合;我们要遵循权限和攻击面最小化等安全设计原则,科学设计模块之间的隔离与接口,提升安全性;低阶架构与设计要遵循高阶的架构与设计原则,在充分理解原有架构与设计的情况下,持续优化;我们要熟悉各种设计模式,重用公共成熟组件和服务,避免重复劳动。

我们要重构腐化的架构及不符合软件工程规范和质量要求的历史代码。我们知道,再好的架构,其生命力也是有限的。随着时间的推移、环境的变化以及新技术、新功能特性的引入,架构也会腐化。面对腐化了的架构,要毫不犹豫地去重构它。同时主动以可信设计原则为导向,去重构不符合软件工程规范和质量要求的历史代码,提升软件架构的生命力。

我们要深入钻研软件技术,尤其是安全技术。软件技术是我们打造产品的基本工具,技术是否先进,技术选择是否合理,将决定我们软件的高度;我们要深入学习架构与设计、编码、测试、安全、可用性、性能、维护性、体验等技术,并科学运用这些技术。

我们要遵守过程的一致性。遵守适用的法律法规、遵循业界共识的标准、规范,确保规范到实现的一致性、代码到二进制的一致性。架构要符合架构原则,设计要遵循设计模式,代码要符合编程规范,最终做到需求与实现一致,达成各项对客户的承诺。我们只有脚踏实地做好每一步,才能真正打造出可信的高质量产品。

为此,我们要改变行为习惯,追求精品。我们要开放透明、积极和勇于揭示问题并主动推动改进。软件开发是一种创造性和艺术性的工作,需要充分发挥我们的聪明才智和潜力。我们要改变只重视功能结果、不重视代码质量的行为习惯,要严格遵守软件工程规范;改变被动的修修补补;改变碎片化知识获取,主动去学习提升并贡献经验、代码,形成共享知识库。我们需要改变的行为和习惯还有很多,对绝大多数人来讲都将是一个痛苦的转变过程,会脱一层皮,但我相信大家能够迎接这种挑战。

更为重要的是,我们将通过变革形成一套适应上述变化的流程、组织与考核机制。我们要完善并增强透明、可回溯和可审计的全流程管理机制,以可信的视角,从初始设计、完整构建到产品生命周期管理,全面提升软件工程能力和实践。我们将全面强化以Committer角色为核心的代码审核和提交机制,代码经过更加严格和系统的审核才能合入版本。为此我们将建立一支更高水平的Committer角色群体,负责软件架构的看护、代码的审核和提交,整体保障合入代码的高质量我们要变革考核机制,要让架构设计好、代码写得好的人脱颖而出,对编程能力不满足要求的人给予帮助和培训。但任何人如果编写的代码长时间不能合入版本,将会被团队抛弃

过去一百年来,世界上许多成功的公司都因不能适应变化而倒下。要适应外部变化,唯有自我进化,我们必须保持开放和持续变革。董事会已决定,全面提升软件工程能力与实践将以变革的方式来开展,由轮值董事长徐直军总负责,公司初始投入20亿美元,计划用5年时间,在ICT基础设施领域实现为客户打造可信的高质量产品的目标。希望您支持并积极投入到这一伟大的变革。唯有如此,我们才能实现未来的愿景和使命:把数字世界带入每个人、每个家庭、每个组织,构建万物互联的智能世界。

任正非

2018年12月27日


原文地址:http://xinsheng.huawei.com/cn/index.php?app=forum&mod=Detail&act=index&id=4134815


2019 年 1 月 03 日 11:5332431
用户头像

发布了 661 篇内容, 共 343.1 次阅读, 收获喜欢 857 次。

关注

评论 16 条评论

发布
用户头像
赞👍,工匠精神,精益思想,全面质量管理
2019 年 01 月 07 日 13:01
回复
用户头像
不要神话企业领导人了
2019 年 01 月 07 日 10:28
回复
用户头像
不信任不是因为质量问题,任总是装傻还是装聋?
2019 年 01 月 06 日 23:24
回复
你除了口嗨强之外,是能力比任总强,还是贡献比任总多?
2019 年 01 月 08 日 13:25
回复
用户头像
华为往生部又要忙起来了
2019 年 01 月 06 日 10:52
回复
用户头像
弱弱的问一下,现在华为办公室能上外网了?
2019 年 01 月 04 日 18:49
回复
红区不能、黄区大部分网站都可以、绿区全部可以。红区越来越少了。
2019 年 01 月 05 日 18:46
回复
用户头像
互联网公司早就这样儿了,你现在才转变?
2019 年 01 月 04 日 13:07
回复
人家是珠穆朗玛峰更进一步!互联网那些小鱼🐠呵呵
2019 年 01 月 05 日 22:25
回复
用户头像
既是质量工程的号召,也是吹响国际政治层面“相信华为”的号角
2019 年 01 月 03 日 19:32
回复
用户头像
校招生刚签了华为软件岗,希望入职后能学习规范的开发模式和代码风格。😇😇
2019 年 01 月 03 日 19:23
回复
用户头像
加班
2019 年 01 月 03 日 18:44
回复
用户头像
任总知识面很广啊,上到哲学下到代码,了不起
2019 年 01 月 03 日 18:19
回复
我在大浪的研发中心主任名下有几百项专利,有没有上千没有统计过
2019 年 01 月 09 日 08:38
回复
用户头像
任何公司和团队都应做出如此决定。有如此说明中国大部分公司都口头上重视代码质量,但是实际上还是以功能、业务为主,质量退居二线。。。
2019 年 01 月 03 日 16:31
回复
用户头像
任总高瞻远瞩啊。
2019 年 01 月 03 日 14:55
回复
没有更多评论了
发现更多内容

Week 2 作業一 : OOD 5 principles [SOLID]

--------世界中心---------

OOD SOLID 架構師 面向對象編程 面向對象編程原則

Week 2 學習總結

--------世界中心---------

Java 架構師 學習

【架构师训练营1期】第二周学习总结

诺乐

week2

张兵

极客大学架构师训练营

第二周学习总结

熊桂平

极客大学架构师训练营

【架构师训练营 1 期】第二周作业

诺乐

面向对象编程与软件设计原则

zero2onemore

第二周作业

Geek_ac4080

框架设计作业

ABS

第二周作业一

dll

训练营-第二周-作业二

行者

第二周作业

zero2onemore

架构师第 2 课作业及学习总结

小诗

极客大学架构师训练营

ARTS Week11

丽子

Spring 5 中文解析数据存储篇-JDBC数据存储(中)

青年IT男

Spring5

架构师训练营第一期——第二周作业

tao

架构第二周总结

Geek_Gu

极客大学架构师训练营

逼着面试官问了我ArrayList和LinkedList的区别,他对我彻底服了

沉默王二

Java ArrayList linkedlist

Week_02

golangboy

一篇搞定前端高频手撕算法题(36道)

执鸢者

面试 算法 前端

SpringBoot系列(2)-第一个SpringBoot程序

引花眠

springboot

【架构师训练营第 1 期 02 周】 作业

Geek_4437a0

极客大学架构师训练营

架构师训练营第一期——第二周总结

tao

ARTS打卡 第18周

引花眠

微服务 ARTS 打卡计划

框架设计原则

wing

极客大学架构师训练营

SOLID五大框架设计原则

Zzzz

极客大学架构师训练营

Week_02学习总结

golangboy

第2周

paul

架构师训练营1期3班-袭望-第二周

袭望

第二周作业

kevin

架构师训练营第 1 期 - 第2周 - 作业

wgl

任正非公开信:投入20亿美元全面提升华为软件质量-InfoQ