FreeBSD 中文社区 2025 第二季度问卷调查
FreeBSD 中文社区(CFC)
VitePress 镜像站QQ 群 787969044视频教程Ⅰ视频教程Ⅱ
  • FreeBSD 从入门到追忆
  • 中文期刊
  • 状态报告
  • 发行说明
  • 手册
  • 网络文章集锦
  • 笔记本支持报告
  • Port 开发者手册
  • 架构手册
  • 开发者手册
  • 中文 man 手册
  • 文章
  • 书籍
  • FreeBSD 中文期刊
  • 编辑日志
  • 2025-123 下游项目
    • FreeBSD 发布工程:新主管上任
    • GhostBSD:从易用到挣扎与重生
    • BSD Now 与将来
    • 字符设备驱动教程(第三部分)
    • 学会走路——连接 GPIO 系统
    • FreeBSD 中对 SYN 段的处理
    • FreeBSD 2024 年秋季峰会
  • 2024-1112 虚拟化
    • 字符设备驱动程序教程(第二部分)
    • 面向 Linux 和 Windows 用户的 bhyve
    • Xen 与 FreeBSD
    • Wifibox:一种嵌入式虚拟化无线路由器
    • 嵌入式 FreeBSD:Fabric——起步阶段
    • DGP:一种新的数据包控制方法
    • 会议报告:我在都柏林的 EuroBSDCon 体验
  • 2024-0910 内核开发
    • 字符设备驱动程序教程
    • VPP 移植到了 FreeBSD:基础用法
    • 利用 Kyua 的 Jail 功能提升 FreeBSD 测试套件的并行效率
    • FreeBSD 上的 Valgrind
    • 嵌入式 FreeBSD:探索 bhyve
    • TCP/IP 历险记:FreeBSD TCP 协议栈中的 Pacing
    • 实用软件:实现无纸化(Paperless)
  • 2024-0708 存储与文件系统
    • FreeBSD 中的 NVMe-oF
    • FreeBSD iSCSI 入门
    • 使用 ZFS 原生加密保护数据
    • 嵌入式 FreeBSD:打造自己的镜像
    • TCP LRO 简介
    • 基于 Samba 的时间机器备份
  • 2024-0506 配置管理对决
    • 基本系统中的 mfsBSD
    • rdist
    • Hashicorp Vault
    • 在 GitHub 上向 FreeBSD 提交 PR
    • 悼念 Mike Karels
    • 2024 年 5-6 月来信
    • 嵌入式 FreeBSD 面包板
    • TCP/IP 历险记:TCP BBLog
    • 实用软件:开发定制 Ansible 模块
  • 2024-0304 开发工作流与集成
    • FreeBSD 内核开发工作流程
    • FreeBSD 与 KDE 持续集成(CI)
    • 更现代的内核调试工具
    • 从零开始的 ZFS 镜像及 makefs -t zfs
    • 提升 Git 使用体验
  • 2024-0102 网络(十周年)
    • FreeBSD 中的 RACK 栈和替代 TCP 栈
    • FreeBSD 14 中有关 TCP 的更新
    • if_ovpn 还是 OpenVPN
    • SR-IOV 已成为 FreeBSD 的重要功能
    • FreeBSD 接口 API(IfAPI)
    • BATMAN:更优的可移动热点网络方式
    • 配置自己的 VPN——基于 FreeBSD、Wireguard、IPv6 和广告拦截
    • 实用软件:使用 Zabbix 监控主机
  • 2023-1112 FreeBSD 14.0
    • LinuxBoot:从 Linux 启动 FreeBSD
    • FreeBSD 容器镜像
    • 现在用 Webhook 触发我
    • 新的 Ports 提交者:oel Bodenmann (jbo@freebsd.org)
  • 2023-0910 Port 与软件包
    • 回忆录:与 Warner Losh(@imp)的访谈
    • 在你自己的仓库中定制 Poudriere 源
    • Wazuh 和 MITRE Caldera 在 FreeBSD Jail 中的使用
    • PEP 517
    • CCCamp 2023 旅行报告
  • 2023-0708 容器与云
    • 在 Firecracker 上的 FreeBSD
    • 使用 pot 和 nomad 管理 Jail
    • 会议报告:C 与 BSD 正如拉丁语与我们——一位神学家的旅程
    • 抒怀之旅:与 Doug Rabson 的访谈
    • 基于 Jail 的广告拦截教程
    • 我们收到的来信
  • 2023-0506 FreeBSD 三十周年纪念特刊
    • CheriBSD 近十多年的历程
    • AArch64:成为 FreeBSD 新的一级架构
    • 岁月如梭:我个人的时间线
    • 安装 FreeBSD 1.0:回顾 30 年前
    • ZFS 是如何进入 FreeBSD 的呢?
    • 我不是来自约克郡的,我保证!
    • 回忆录:采访 David Greenman Lawrence
    • FreeBSD 和早期的 Unix 社区
    • 早期的 FreeBSD 移植
    • FreeBSD 30 周年:成功的秘诀
    • FreeBSD 在日本:回忆之旅与今日之实
  • 2023-0304 嵌入式
    • CheriBSD port 和软件包
    • 让我们来试试 ChatGPT
    • GPU 直通
  • 2023-0102 构建 FreEBSD Web 服务器
    • ZFS 的原子 I/O 与 PostgreSQL
    • 虚拟实验室——BSD 编程研讨会
    • ZFS 简介
    • 会议报告:落基山庆祝女性计算机科学家
    • 进行中的工作/征求反馈:数据包批处理
    • 基金会与 FreeBSD 桌面
  • 2022-1112 可观测性和衡量标准
    • 在 FreeBSD 的 DDB 内核调试器中编写自定义命令
    • DTrace:老式跟踪系统的新扩展
    • 基于证书的 Icinga 监控
    • 活动监控脚本(activitymonitor.sh)
    • 实用 IPv6(第四部分)
    • EuroBSDCon 会议报道
    • 实用 Port:Prometheus 的安装与配置
    • 书评:《用火解决问题:管理老化的计算机系统(并为现代系统保驾护航)》Kill It with Fire: Manage Aging Computer Systems (and Future Proof Modern Ones)
  • 2022-0910 安全性
    • CARP 简介
    • 重构内核加密服务框架
    • PAM 小窍门
    • SSH 小窍门
    • 实用 IPv6(第三部分)
    • 书评:Understanding Software Dynamics(深入理解软件性能——一种动态视角)—— Richard L. Sites 著
    • 访谈:保障 FreeBSD 安全性
    • MCH 2022 会议报告
  • 2022-0708 科研、系统与 FreeBSD
    • 在 FreeBSD 上构建 Loom 框架
    • 教授本科生 Unix 课程
    • FreeBSD 入门研讨会
    • 实用 IPv6(第二部分)
    • 在 2022 年及以后推广 FreeBSD
    • 进行中的工作/征求反馈:Socket 缓冲区
    • FreeBSD 开发者峰会报告
    • 支持 Electromagnetic Field 2022
  • 2022-0506 灾难恢复
    • 使用 FreeBSD 构建高弹性的私有云
    • LLDB 14 —— FreeBSD 新调试器
    • 实用 IPv6(第一部分)
    • 利用 netdump(4) 进行事后内核调试
    • 进行中的工作/征求反馈:FreeBSD 启动性能
    • 实用 Port:在 OpenZFS 上设置 NFSv4 文件服务器
  • 2022-0304 ARM64 是一级架构
    • FreeBSD/ARM64 上的数据科学
    • Pinebook Pro 上的 FreeBSD
    • 嵌入式控制器的 ACPI 支持
    • 进行中的工作/征求反馈:Lumina 桌面征集开发人员
    • 实用 Port:如何设置 Apple 时间机器
  • 2022-0102 软件与系统管理
    • 为 FreeBSD Ports 做贡献
    • 使用 Git 贡献到 FreeBSD Ports
    • CBSD:第一部分——生产环境
    • 将 OpenBSD 的 pf syncookie 代码移植到 FreeBSD 的 pf
    • 进行中的工作/征求反馈:mkjail
    • 《编程智慧:编程鬼才的经验和思考》(The Kollected Kode Vicious)书评
    • 会议报告:EuroBSDCon 2021 我的第一次 EuroBSDCon:一位新组织者的视角
  • 2021-1112 存储
    • 开放通道 SSD
    • 构建 FreeBSD 社区
    • 与完美操作系统同行 27 年
    • 进行中的工作/征求反馈:OccamBSD
    • 通过 iSCSI 导入 ZFS ZIL——不要在工作中这样做——就像我做的那样
  • 2021-0910 FreeBSD 开发
    • FreeBSD 代码审查与 git-arc
    • 如何为 FreeBSD 实现简单的 USB 驱动程序
    • 内核开发技巧
    • 程序员编程杂谈
  • 2021-0708 桌面/无线网
    • 通往 FreeBSD 桌面的直线路径
    • FreeBSD 13 中的人机接口设备 (HID) 支持
    • Panfrost 驱动程序
    • 用 Git 更新 FreeBSD
    • FreeBSD 的新面孔
    • 想给你的桌面加点佐料?
  • 2021-0506 安全
    • 七种提升新安装 FreeBSD 安全性的方法
    • copyinout 框架
    • 使用 TLS 改善 NFS 安全性
    • Capsicum 案例研究:Got
    • 对 Jail 进行安全扫描
  • 2021-0304 FreeBSD 13.0
    • 展望未来
    • FreeBSD 13.0 工具链
    • FreeBSD 13.0 中有新加载器吗?
    • TCP Cubic 准备起飞
    • OpenZFS 中的 Zstandard 压缩
    • 会议报告:FreeBSD 供应商峰会
    • Git 不够吗?
  • 2021-0102 案例研究
    • Tarsnap 的 FreeBSD 集群
    • BALLY WULFF
    • Netflix Open Connect
    • FreeBSD 的新面孔
    • 写作学者的 FreeBSD
    • 在世界之巅
  • 2020-1112 工作流/持续集成(CI)
    • FreeBSD Git 快速入门
    • 使用 syzkaller 进行内核 Fuzzing
    • Mastering Vim Quickly 书评
    • 线上会议实用技巧
    • 在控制台上进行网络监控
  • 2020-0910 贡献与入门
    • 采访:Warner Losh,第 2 部分
    • 代码审查
    • 撰写良好的提交消息
    • 如何在不是程序员的情况下做出贡献——成为 FreeBSD 译者
    • 如何成为文档提交者
    • 谷歌编程之夏
    • 为 FreeBSD 期刊撰写文章
    • 你为什么使用 FreeBSD
    • FreeBSD 的新面孔
  • 2020-0708 基准测试/调优
    • FreeBSD Friday
    • 采访:Warner Losh,第 1 部分
    • 构建和运行开源社区
    • 在 FreeBSD 上轻松搭建我的世界(Minecraft)服务器
    • FreeBSD 的新面孔
  • 2020-0506 网络性能
    • 内核中的 TLS 卸载
    • 访谈:Michael W Lucas
    • FreeBSD 桌面发行版
    • 使用 Poudriere 进行 Port 批量管理
    • FreeBSD 的新面孔
由 GitBook 提供支持
LogoLogo

FreeBSD 中文社区(CFC) 2025

在本页
在GitHub上编辑
导出为 PDF
  1. 2022-0102 软件与系统管理

《编程智慧:编程鬼才的经验和思考》(The Kollected Kode Vicious)书评

上一页进行中的工作/征求反馈:mkjail下一页会议报告:EuroBSDCon 2021 我的第一次 EuroBSDCon:一位新组织者的视角

最后更新于22天前

  • 原文链接:

  • 作者:BENEDICT REUSCHLING

亲爱的 Practical Ports,

我是否应该抽时间阅读 George V. Neville-Neil 的《The Kollected 编程智慧:编程鬼才的经验和思考》,而不是一本关于我工作所需的新编程语言的书?我没有太多时间阅读,所以需要谨慎选择。我也不明白,像 KV 这样使用笔名而非真名的人,如何能被认真对待,特别是当他们给别人提供如此主观的建议时。

—— 一位时间不多的怀疑读者

亲爱的怀疑者,

你是否听说过 Alice Addertongue 或 Silence Dogood?或者 Poor Richard 有没有让你想起什么?这些都是本杰明·富兰克林(Benjamin Franklin)使用的笔名。在富兰克林的时代,笔名和漫画形象是非常常见的,尽管通常很容易知道是谁在背后写作。这些不同的漫画形象不仅让富兰克林能够为他的读者(即他自己报纸的读者)提供多角度的看法,还允许他运用夸张、讽刺和奇思妙想来娱乐读者并影响他们的观点。因此,使用化名和人格写作并不是新鲜事,实际上,既然你在给 Practical Ports 写信,你也是在参与这种情形。

在我们讨论书籍之前,让我们先解决你抽出时间读书的问题。“每个人都有时间。别再看该死的《迷失》了!”—— Gary Vaynerchuk,2008 年在 Web 2.0 Expo NY 说的

不过,好吧,撇开这个,我可以理解如今时间很难抽出。而且,能读的书毕竟有限(如果是好书的话,更加难得!)。无休止地刷新闻或社交媒体不算是阅读,陷入 Youtube 的无尽循环也不算。书籍仍然是知识和娱乐的相关来源——或许现在比以往任何时候都更为重要——这就是为什么我抽时间来审阅这本书。即便在充斥着电子信息的互联网海洋中,翻开纸质书页仍然能吸收永恒的智慧并享受乐趣。

现在,关于你是否应该为《编程智慧:编程鬼才的经验和思考》这本书腾出一些时间的问题。对于尚未接触 KV 专栏的读者,我应该解释一下,这本书是 KV 在 ACM Queue 列刊中同名专栏的合集,按照主题分组。作者多年写作这些专栏,并将最好的文章收集在书中,按主题进行组织,并附上简短的介绍。至于他是如何让计算机科学巨匠唐纳德·E·克努斯(Donald E. Knuth)为书写序的,或许永远是作者的秘密。简直是受封了!我非常喜欢章节开头的引言,这里有不少能够概括你即将阅读的内容的引用。(例如:哦,Bullwinkle,那招永远不管用!— Rocky J. Squirrel)

如果你从未读过 KV 的专栏,要知道,它们遵循的是传统的问答/建议专栏格式——这个格式古老得可以追溯到本杰明·富兰克林的解构和重构方法,当然,也可以追溯到苏格拉底。书中的信件/问题呈现的是一个困惑或困扰的人向 KV 寻求建议的情境。这些问题既真实又相关,常常和我从学生那里听到的类似。一些较后的专栏显然是基于真实的信件,而一些较早的专栏则是代笔写作。在所有情况下,答案/建议都会回应问题,解释、化解、解构、重组或反思假设,同时为主题提供新的见解。提供的意见通常是出于良好意图,并给出所期望的建议。这些信件中的许多(如果不是全部的话)可能以禅宗故事中常用的词语结尾:“于是,学生得到了启发。”

查看目录,你会看到以下几组主题:

  • 手头的代码 —— 讨论程序员(像你)必须面对的日常烦恼和思考——从分配过多内存、异常处理(或缺乏处理)到正确的日志记录和编码风格讨论。本章主要吸引程序员,对于那些偶尔使用计算机、好奇为什么互联网不起作用的用户不太适合。

  • 编程难题 —— 探讨更为哲学性的问题,比如什么是好的编程语言,如何避免无休止地包含文件的意大利面条式代码,为什么测试很重要,以及代码扫描器和调试策略等元主题。所有这些都值得一读,如果你有多年的编程经验,你肯定会在其中找到一个熟悉的故事。如果你曾问过自己为什么现在的事情是这样,那接下来的章节将为你解答。

  • 系统设计 —— 讨论我们日常使用的系统设计中(大多数是错误的)选择。永恒话题如身份验证与加密、跨站脚本攻击、钓鱼和感染(后者指的是计算机系统),以及 UI 设计将让你频频点头同意,同时也会对糟糕设计的典型例子摇头。我留给你自己去发现为什么 Java 会出现在这一章节。

  • 机器对机器 —— 讨论延迟、扩展失败、协议设计以及日益增长的标准列表。如果你了解这位作者或知道他,那么你不会感到惊讶,这一部分并不是在谈论网络如何连接这些机器。如果你觉得这很让人不安,那就等着读下一部分吧……

  • 人类对人类 —— 思考如何命名你的主机,别让你的自尊心介入,代码面试问题,以及“油漆小棚”现象(即无关紧要的事物成为争论焦点)。人们为计算带来了许多有趣的特质——如果它们只是好特质就好了。

在每一章中,作者通过故事揭示洞察力和经验,进行警示和教育。尽管这些故事常常带有些许抱怨(或许是因为看到了太多类似的情况),但没有一页让你觉得事情已经无望。相反,书中充满了实用的建议,夹杂着个人的偏好和推荐,并且始终以机智和幽默的方式传达。我能想象这本书有两个很好的用途。一个是作为轻松娱乐的阅读,另一个是作为参考书。专栏内容足够简短,可以在短暂的休息时(搭配你喜欢的饮料)或睡前(当然,不包括噩梦)阅读。把书放在容易拿到的地方,这样当有问题时,你可以迅速翻阅相关章节。另一个想法是,当争论发生或设计决策即将做出时,把它交给你的同事和同行。“让我们翻到《Vicious》书中,提醒自己什么是不该做的”,当讨论陷入僵局,需要新视角时,或许可以这样说。经验丰富和新来的同事们都会在这些专栏中找到有趣且相关的内容,他们会一边点头表示认同(我也经历过),一边微笑着想起那些有趣的轶事。

现在,回到你是否应该在有限的阅读时间里选择《The Kollected 编程智慧:编程鬼才的经验和思考》而不是一本新编程语言书籍的问题,我会说:“是的。”我认为你应该阅读 KV 的书,但不要期望从中找到“使用这个巧妙的代码片段让代码更快”或“使用 Emacs 作为编辑器会让你生产力翻倍”之类的建议。另一种编程语言可能会在简历上看起来不错,但最终,这些不过是行业工具罢了。我们所做的事情远不止编写代码!这本书将为你阐明这一点,展现这个行业的喜怒哀乐。你的阅读体验可能不同,但我认为阅读这本书并内化其教诲,会对你大有裨益。最后让我用另一句引言结束:

“去年の癡僧 ち そう今又来たる(去年癡僧今又来)”

——日本禅宗诗人良寛大愚


PP BENEDICT REUSCHLING 是 FreeBSD 项目的文档提交者,也是文档工程团队的成员。他是 FreeBSD 基金会董事会的副主席。过去,他曾在 FreeBSD 核心团队服务了两个任期。他在德国达姆施塔特应用科技大学管理一个大数据集群,同时为本科生教授“开发者的 Unix”课程。Benedict 还是每周 bsdnow.tv 播客的主持人之一。

A review of The Kollected 编程智慧:编程鬼才的经验和思考
https://www.youtube.com/watch?v=EhqZ0RU95d4