大多数情况下,如果你正在做的事情无法在互联网上找到答案,那么这通常意味着这个问题很难或者很重要,或者两者都是
尽可能多地删除代码
语法糖通常是不好的
简单往往是最难的
拥有各种各样的工具,并知道该用哪些工具来完成工作
了解最常用的工具的内部结构,如 git 和 bash
为重复的工作流程构建自己专用的工具
从最好的资料中进行学习(这里 Matt 举例称他在学习 Go 时阅读了标准库)
如果代码看起来很丑,那很可能是一个严重的错误
如果必须编写不是文档字符串 (docstring) 的注释,则应该考虑对这段代码进行重构
如果不了解所编写的程序是如何在生产环境中运行的,那就说明不了解程序本身。优秀的工程师知道他们的程序在各种环境中是如何运行的
上面这条经验对于构建管道也适用
谨慎使用他人的代码
互联网上找到的代码大多数都很糟糕,有时候自己写一个更好的版本会更容易
永远不要直接依赖自己可以轻松重写的小型库,或本应很小的大型库
知道什么时候该打破规则。对于“不要重复自己”这种规则,有时候重复比使用依赖要好
将代码组织成模块、包和函数很重要。了解 API 的边界位置是一门艺术
大多数情况下应选择最有效的工具,但也要选择自己所知道的。Arch Linux 是现代开发者最高效的操作系统吗?对我来说,是的,但对大多数人来说,可能不是
避免圈复杂度 (Cyclomatic complexity)
避免多层嵌套条件
正确命名变量,这也是一门艺术
虽然很少见,但有时报错可能确实是编译器的问题
谨慎使用深奥的语言特性,但在应该使用的时候还是要使用
技术的传播并不均衡对等。例如,前端开发者可以从负责底层技术的工程师那里学到许多东西,云工程师可从 JavaScript 开发者身上学到用户体验和可用性方面的知识。但反过来却未必成立
因此,不同类型的工程师看待世界的方式是不同的
部分程序员的效率是其他程序员的 10 倍
成为 10 倍程序员与 10 倍员工这两者之间没有相关性(或许是负相关)
好的 API 易于使用且难以误用
配置七边形(Matt 自创的术语)从硬编码值开始,到环境变量、CLI Flag、配置文件、模板化配置文件、DSL、通用 bash 脚本,再到硬编码值。开发者应了解这个七边形中的各个位置。
责任编辑:haq
-
编程
+关注
关注
88文章
3619浏览量
93774 -
代码
+关注
关注
30文章
4791浏览量
68683
原文标题:编程一万小时是种什么样的体验?
文章出处:【微信号:pcbgood,微信公众号:奈因PCB电路板设计】欢迎添加关注!文章转载请注明出处。
发布评论请先 登录
相关推荐
评论