闭包捕获:为什么同一个循环变量在不同语言中行为截然不同

1964年,Peter Landin在一篇题为《The Mechanical Evaluation of Expressions》的论文中首次提出了"闭包"(closure)的概念。他将闭包定义为一个包含λ表达式及其相关环境的"信息束"。六十年后,这个概念几乎出现在所有现代编程语言中——JavaScript、Python、Rust、Go、Swift、C++、Java——但每种语言的实现方式却大相径庭。 ...

9 min · 4494 words

OOM Killer 的评判算法为何总是杀错进程?从启发式评分到生产环境的生存指南

凌晨三点,线上告警。你打开监控面板,发现主数据库进程消失了,而那个只占用几兆内存的后台日志收集进程却安然无恙。dmesg 的输出冷酷而简洁: Out of memory: Kill process 18472 (postgres) score 891 or sacrifice child 这不是电影情节,而是无数运维工程师的真实经历。Linux 内核的 OOM Killer 本应是系统安全的最后一道防线,但它那套基于启发式评分的选杀机制,在过去二十多年里"误杀"了无数关键进程。问题来了:这套机制到底是怎么工作的?为什么数据库进程总是第一个被选中?又该如何让关键服务在内存危机中存活下来? ...

6 min · 2857 words

内存泄漏:为什么即使有垃圾回收,你的程序仍在悄悄泄漏内存

title: “内存泄漏:为什么即使有垃圾回收,你的程序仍在悄悄泄漏内存” date: “2026-03-05T16:36:29+08:00” description: “从2012年AWS宕机事件到Chrome DevTools堆快照分析,深入剖析内存泄漏的本质——不是技术缺陷,而是资源管理的系统性失误。本文涵盖手动内存管理语言(C/C++)与垃圾回收语言(Java、Go、JavaScript)的不同泄漏模式,对比Valgrind与AddressSanitizer的检测策略,揭示RAII、智能指针、弱引用等防御机制的设计哲学。” draft: false categories: [“系统架构”, “编程语言”, “技术原理”] tags: [“内存泄漏”, “垃圾回收”, “内存管理”, “RAII”, “Valgrind”, “AddressSanitizer”, “智能指针”, “性能优化”] 2012年10月22日,Amazon Web Services遭遇了一次看似普通的故障。一台数据收集服务器被更换后,DNS地址没有正确传播,导致部分服务器持续尝试连接这台已下线的机器。这个持续的重试行为触发了内存泄漏。更致命的是,负责监控内存的内部警报系统同时失效——所有仪表盘显示绿色,而系统正在走向崩溃。 ...

12 min · 5648 words