10 月 23 - 25 日,QCon 上海站即将召开,现在购票,享9折优惠 了解详情
写点什么

20 年编程老兵的代码价值观 | 极客时间

  • 2019-05-16
  • 本文字数:1647 字

    阅读完需:约 5 分钟

20年编程老兵的代码价值观 | 极客时间

代码,是我们交流的语言和处世的名片,更是未来你找工作的简历。


你好,我是范学雷,我想和你来聊聊“怎么写好代码”这件事。


2014 年 2 月,安全研究人员爆出苹果公司旗下的 iOS 和 OS X 操作系统出现了严重的安全漏洞,黑客可以利用这一漏洞轻松获取用户的数据。下面的这段 C 语言伪代码简单描述了当时的漏洞情况。


    if ((error = doSomething()) != 0)        goto fail;                 goto fail;        if ((error= doMore()) != 0)                goto fail;fail:        return error;
复制代码


相信你一眼就能看出来,在这段代码的第三行出现了多余的代码,导致后面的其他代码“失效”,这一低级错误也让所有的安全人员大跌眼镜。你可能会说,这开发人员真是太粗心了,是不是他复制代码的时候,多复制了一行,然后忘记删除了?


可能是这个原因,但问题的源头肯定不是粗心。有专家在看完了代码文件之后,发现相关的 Bug 代码没有正确使用缩进,也没有正确使用括号,并且其中的空格、制表符和代码注释也都不统一。


换句话说,这段代码就是所谓的“烂代码”。


工作中,你要是说谁的代码烂,那我估计很快你就会挑起一场战争。因为对于烂代码和好代码的定义,真的是千人千面。现实环境的变化,也影响着你我对于代码“好”与“坏”的判断标准。


虽然对于“什么是优秀的代码“难以形成一致意见,但是这么多年的经验,让我对代码“好”与“坏”积累了一些自己的看法。


“好”的代码应该:


  1. 容易理解;

  2. 没有明显的安全问题;

  3. 能够满足最关键的需求;

  4. 使用规范的命名;

  5. 经过充分的测试。


“坏”的代码包括:


  1. 难以阅读的代码;

  2. 浪费大量计算机资源的代码;

  3. 代码风格混乱的代码;

  4. 复杂的、不直观的代码;

  5. 没有经过适当测试的代码。


当然,上面的列表还可以很长很长,长到一篇文章都列不完、长到我们都记不住的程度。如果用一句话来概括的话,我觉得“最适合当前现实环境的代码,才是最优秀的代码。”我将会在极客时间上的专栏《代码精进之路》中详细阐述这句话的含义。

我是谁?

我是范学雷,现在是 Oracle 的主任工程师,也是 OpenJDK 和 Java 安全的评审成员。从 1998 年我参加工作以来,一直在一线从事编程工作,期间在 OpenJDK 社区参与代码评审的工作。作为一个代码评审者,不是批准或者拒绝提交的代码,而是提出合理的建议,帮助代码提交者规避这些失误或者错误,编写出更优秀的代码。


作为解决现实问题的软件工程师,不管资历深、资历浅,我们都需要编写优秀的代码,并且是越来越优秀的代码,因为这是我们生存的基本依靠。作为活在现实世界的技术工程师,我们需要保持长久的竞争力,甚至是越来越强的竞争力,因为这是改善我们生存质量的最好方式。


我常和一些程序员说:“每一行代码,都体现着程序员的修为,思考问题的深度,甚至是处理问题的习惯和态度。代码,是我们交流的语言和处世的名片,更是未来你找工作的简历。”

这个专栏我会讲些什么?

我会围绕代码的规范、性能和安全三个方面展开,选取工作中遇到的最高频的、实用的细节问题,从重要性、易犯错的场景以及最优的处理方案等角度来讲解,让你知道好的代码应该怎么写,怎么定义好的代码。

互动讨论

import java.util.HashMap;import java.util.Map;
class Solution { /** * Given an array of integers, return indices of the two numbers * such that they add up to a specific target. */ public int[] twoJia(int[] nums, int target) { Map<Integer, Integer> map = new HashMap<>(); for (int i = 0; i < nums.length; i++) { int complement = target - nums[i]; if (map.containsKey(complement)) return new int[] { map.get(complement), i }; map.put(nums[i], i); } throw new IllegalArgumentException("No two sum solution"); }}
复制代码


这段代码中你发现了几个错误呢?同时可以在留言区秀秀你最中意的代码,或者吐槽一下你今年遇到的那些烂代码,并且给你造成了哪些困扰呢?


内容选自极客时间代码精进之路专栏


2019-05-16 15:049571

评论

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

智能门禁的音视频技术应用

anyRTC开发者

音视频 WebRTC 直播 RTC

学习笔记丨浮点数探究

Liuchengz.

C语言 基本数据类型

百度大脑事件图谱:洞察复杂世界中的事件知识

百度大脑

同城快递订单系统架构设计方案

周冬辉

git的几种实用操作(合并代码与暂存复原代码)

良知犹存

git

百度大脑助力旅游场景智能解决方案落地

百度大脑

AWS在线技术峰会2020探班回顾,四大看点不容错过

有只小耳朵

云计算 AI 云原生 金融 医疗

面试官:哪些场景会产生OOM?怎么解决?

艾小仙

Java 架构 面试 编程语言 JVM

当代开发者的好帮手,浅析.NET敏捷开发框架的优势与特点

Philips

敏捷开发 软件开发 .net core 开发工具

实战案例丨GaussDB for DWS如何识别坏味道的SQL

华为云开发者联盟

数据库 sql 算子

QPS、TPS、RT、并发数、吞吐量理解和性能优化深入思考

艾小仙

架构 编程语言

GrowingIO 智能运营产品微前端实践

GrowingIO技术专栏

大前端 智能运营

Code Like Sync, Works Like Async

滴滴普惠出行

Apache Pulsar 社区周报|09-05 ~ 09-11

Apache Pulsar

开源 云原生 Apache Pulsar 消息中间件

JDK15正式发布,划时代的ZGC同时宣布转正

YourBatman

ZGC JDK15

第一周作业,UML图

等燕归

2020年6月最新iOS面试题总结

iOSer

ios 2020 面试 经验总结

架构师训练营第一期-第一周课后 - 作业二

Copy攻城狮辛酸史:含泪“一分钟”跑通MindSpore的LeNet模型

华为云开发者联盟

学习 程序员 mindspore

OBS鉴权实现的宝典秘籍,速拿!

华为云开发者联盟

OBS 签名

入行架构师之前,这7项技能你要先了解一下

华为云开发者联盟

架构 架构设计 架构师

Spring-boot 单元测试

陈靓-哲露

架构师训练营第一期-第一周课后-作业一

餐卡系统设计文档

龙卷风

卧槽!牛逼了!40K+Star!Mall电商实战项目开源回忆录!附源码、教程合集

学习 程序员 架构师 计算机

HTTP必知必会

陈靓-哲露

跨专业学习6个月,成功上岸阿里|滴滴,分享学习路线供大家参考

小Q

Java 学习 架构 面试 基础

分布式系统:数据一致性解决方案

马迪奥

分布式事务 一致性

Rust闭包的虫洞穿梭

袁承兴

rust 函数式编程 闭包

Java基础知识面试题(2020最新版)

Java架构师迁哥

食堂就餐卡系统设计 UML 练习

escray

学习 极客大学架构师训练营 UML

20年编程老兵的代码价值观 | 极客时间_语言 & 开发_范学雷_InfoQ精选文章