【AICon】探索八个行业创新案例,教你在教育、金融、医疗、法律等领域实践大模型技术! >>> 了解详情
写点什么

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"); }}
复制代码


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


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


公众号推荐:

跳进 AI 的奇妙世界,一起探索未来工作的新风貌!想要深入了解 AI 如何成为产业创新的新引擎?好奇哪些城市正成为 AI 人才的新磁场?《中国生成式 AI 开发者洞察 2024》由 InfoQ 研究中心精心打造,为你深度解锁生成式 AI 领域的最新开发者动态。无论你是资深研发者,还是对生成式 AI 充满好奇的新手,这份报告都是你不可错过的知识宝典。欢迎大家扫码关注「AI前线」公众号,回复「开发者洞察」领取。

2019-05-16 15:049315

评论

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

解决方案| anyRTC远程检修应用场景

anyRTC开发者

人工智能 音视频 视频会议 远程协助 电话会议

莆田市属于哪个省?有正规等保测评机构吗?

行云管家

等保 等保测评 等保等级保护

反驳来了!放弃TypeScript?说明你无知!

树上有只程序猿

typescript 代码质量 js

glTF 中基于物理的渲染(PBR)

3D建模设计

基于YOLOv2和传感器的多功能门禁系统

timerring

YOLOv2

GLTF文件格式解析与预览、编辑

3D建模设计

GLTF

HarmonyOS应用侧与前端页面数据通道建立

HarmonyOS开发者

HarmonyOS

5 个适合出海离岸公司的地区推荐

出海的猹

出海企业

国产化操作系统有哪些?适配国产化操作系统堡垒机哪款好用?

行云管家

信创 堡垒机 国产化 国产操作系统 国产

预告!网络安全红队GPT大模型训练直播来袭

云起无垠

揭秘 ChunJun:如何实现 e2e&session 日志隔离

袋鼠云数栈

大数据 开源

创新生产力的新引擎

百度开发者中心

#人工智能 生成式AI 文心一言

北京大上科技发布全球首款25.3英寸彩色墨水屏显示器

硬科技星球

文心一言 VS 讯飞星火 VS chatgpt (93)-- 算法导论9.2 1题

福大大架构师每日一题

福大大架构师每日一题

创新力量重塑生产力

百度开发者中心

文学 #人工智能 生成式AI 文心一言

医院如何实现安全又稳定的跨网文件数据交换呢?

镭速

跨网文件数据交换

GLTF-pipeline

3D建模设计

gltf编辑器

2023百度教育再出发,探索经营增长新空间

彭飞

运行程序提示路径错误?

矩视智能

深度学习 机器视觉

如何将 OBJ 模型转换和压缩为 GLTF 以与 AWS IoT TwinMaker 配合使用

3D建模设计

GLTF

HarmonyOS NEXT带来的DevEco Profiler助您轻松分析应用性能问题

Geek_2d6073

9.19-21,openEuler与您相约2023欧洲开源峰会

openEuler

Linux 开源 操作系统 openEuler

使用Docker构建轻量级Linux容器

互联网工科生

Docker 容器

OpenCloudOS + 英特尔第四代至强处理器:完美适配,加速未来

OpenCloudOS

Linux intel

如何在Blender中压缩/减小GLTF模型的大小

3D建模设计

blender GLTF

华为云CodeArts Check代码检查服务用户声音反馈集锦(1)

华为云PaaS服务小智

云计算 软件开发 华为云

生成式AI的发展与内容质量及安全性的挑战

百度开发者中心

#人工智能 生成式AI 文心一言 千帆大模型平台

Red Giant Magic Bullet Suite for Mac(红巨人调色降噪插件合集下载) v2024.0.0永久激活版

mac

苹果mac Windows软件 Red Giant Magic Bullet 视频后期处理软件

为什么选择事件驱动的微服务架构?

这我可不懂

微服务

基于Web的智慧污水厂2D组态系统

2D3D前端可视化开发

组态软件 智慧水务 智慧污水处理 污水厂组态图 污水厂监控系统

文字图像转换的创新技术

百度开发者中心

#人工智能 生成式AI 千帆大模型平台

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