当前位置: 首页 > news >正文

别用“设计感”掩盖无知:从一次 null == 0 的事故说起

那天下午,我盯着一行再普通不过的代码,足足愣了三分钟:

if (value.Equals(null))
{// 这行居然执行了?!
}

value 是一个 Value 类型的对象,构造时传入的是整数 0——它明明不是 null。调试器里字段正常,内存地址也清清楚楚。可 .Equals(null) 却返回了 true。这已经不是“奇怪”了,这是在挑战我对编程语言的基本信任。

带着一丝不安,我点进了 Value.Equals

public class Value : XXObject, IObject
{public override bool Equals(object obj){return base.Equals(obj);}
}

哦,它自己没实现,直接甩锅给父类 XXObject。那就继续追

public class XXObject : IObject
{public override bool Equals(object? obj){return XXEquals.Equals(_value, obj);}
}

看到这里,我心里咯噔一下:
为什么一个 Equals 要委托给静态类?
为什么 ValueXXObject 都要实现同一个接口 IObject
感觉就是过度抽象+静态工具滥用

但 debug 不能停。我硬着头皮点进 XXEquals.Equals,眼前出现了一段堪称“史诗级轮子”的 switch 大法:

public static new bool Equals(object value, object? obj)
{if (obj is IObject _obj){return Equals(value, _obj.GetValue());}switch (value){case int v:{return obj switch{byte v2 => v == v2,short v2 => v == v2,// ... 省略一堆类型_ => v == XXConvert.ToInt(obj)};}
}

问题就出在最后那个兜底分支:XXConvert.ToInt(obj)
objnull 时,它居然没有抛异常,而是.....返回了 0

我颤抖着手点进去:

public static int ToInt(object? obj, int def = default)
{return ToIntNull(obj) ?? def;
}

def 的默认值是 default(int),也就是 0
所以 ToInt(null)ToIntNull(null) 返回 null?? 0 → 最终得到 0

于是整个链条闭环了:

  • value.Equals(null)
  • XXEquals.Equals(0, null)
  • 0 == XXConvert.ToInt(null)
  • 0 == 0
  • true

那一刻,我悬着的心终于死了:

这不是 bug,这是一个自以为“通用”的轮子,在用一套看似合理实则荒谬的逻辑,系统性地践踏语言最基本的契约。

值得庆幸的是,在 .NET(C# 7.0+)中,我们不需要依赖可能被重写的 Equals== 来判断 null
官方早已提供了一种语义明确、无法被篡改的 null 检查方式

if (value is null)
{// 安全!这永远只检查引用/实例是否为 null
}

所以,即使底层有人造了“null 转 0”的轮子,只要上层用 is null,就能免疫这类静默错误。

但这只是“止血”,不是“治病”。

虽然 is null 能让我们暂时避开陷阱,但问题的根源依然存在

别用“设计”掩盖无知

说实话,看到 XXConvert.ToInt(null) 返回 0 的那一刻,我气笑了。

不是因为代码复杂,而是因为这种设计透露出一种令人不安的傲慢

“我知道用户可能会传 null,但我不想让他们处理异常——我替他们‘智能’地处理成默认值。”

听起来很贴心?不,这是对语义的背叛

在几乎所有主流编程语言中,null 都代表“无值”、“缺失”、“未初始化”。而 0 是一个明确的、有效的值。把“无”等同于“零”,就像把“没人来开会”理解成“来了一个人,他叫张三,职位是 0 号员工”一样荒谬。

更可怕的是,这种“智能”被包装在三层抽象之下:

  • 接口 IObject(看似规范)
  • 基类 XXObject(看似复用)
  • 静态工具类 XXEquals + XXConvert(看似解耦)

结果呢?解耦不解祸,封装不封错
所有调用者都被蒙在鼓里,直到某天某个 if (obj.Equals(null)) 突然走错分支,系统在静默中走向崩溃。


这件事让我意识到:
所谓专业,不是你会造多复杂的轮子,而是你清楚哪些边界绝不能碰——比如相等性、空值语义、类型安全这些设计底线。

在这个行业,最昂贵的轮子,从来不是重复造的,而是造歪了还装上车的

http://www.jsqmd.com/news/54253/

相关文章:

  • 2025年下半年江苏智能煤流系统、煤矿智能化系统开发公司综合推荐指南
  • 使用Postman进行接口测试、接口自动化和集成CI/CD
  • 信创环境下的一体化全栈智能运维
  • AI训练素材与数据集供应商推荐:卓特视觉的专业解决方案
  • 2025年国内靠谱的AGV货架生产厂家推荐榜单,立体货架/重载货架/中型货架/组合式货架/流利式货架/背网货架AGV货架批发厂家推荐榜单
  • 28223E2125263E2121203E212424384722B0开
  • 【251128】CF2164 Div.1+2 vp 总结
  • 2025长沙公务员面试培训机构排名,速看!,湖南长沙公务员面试技术引领与行业解决方案解析
  • 2025年四川成都奖杯奖牌定制、奖章证书定制、奖杯定制、水晶奖杯定制、奖牌定制品牌厂家企业推荐top5指南
  • 2025年工业冷风机车间降温技术全解析,铁皮棚车间降温/焊装车间通风降温/压铸车间通风降温/机械厂车间降温工业冷风机厂商推荐排行
  • 2025年长沙公务员面试机构排行榜:前五强揭晓,湖南长沙公务员面试排行优质品牌选购指南
  • 车间降温新方案:工业冷风机2025年趋势,五金车间通风降温/焊装车间通风降温/钢构车间通风降温/制造业车间通风降温工业冷风机企业口碑推荐
  • 详细介绍:【k8s】Deployment、StatefulSet、DaemonSet
  • 2025非遗新中式品牌排行TOP榜,这些品牌正走红,非遗新中式推荐排行色麦新中式层层把关品质优
  • 2025年高定服装加盟品牌市场占有率排行,高定服装加盟采购色麦新中式市场认可度高
  • 2025国风源头排行榜发布,这些品牌上榜!,国风源头推荐排行技术领航者深度解析
  • 2025年工业冷风机维护保养全攻略,延长设备使用寿命,铁皮房车间降温/高大车间厂房通风降温/炼钢车间通风降温工业冷风机公司口碑推荐
  • 2025年新中式高定服装加盟五大推荐品牌,新中式高定服装加盟批发精选优质厂家
  • 2025年靠谱的四川变形缝_变形缝厂家实力及口碑推荐榜
  • 2025年国内正规的AGV货架批发厂家找哪家,悬臂货架/高位货架/精益管料架/贯通货架/牛脚式货架/可调节货架/冷库货架AGV货架产品选哪家
  • HTML基础--面向后端
  • 2025年长沙公务员面试选哪家?最新排名出炉,湖南长沙公务员面试赋能企业生产效率提升与成本优化
  • 2025年工业冷风机车间降温技术全解析,电炉车间通风降温/钢结构车间夏季降温/机械厂车间降温/电镀车间通风降温工业冷风机生产厂家哪家好
  • 中考前最后一个假期!选这些数学老师带你冲刺寒假
  • 2025中国HR SaaS厂商AI进度大盘点
  • SQL Server设置用户查看指定数据库的指定表单
  • 注重交流的成人英语课程怎么选?五大维度深度解析
  • 气体分析仪厂家综合实力榜:2025年度十大气体分析仪厂家排名,权威榜单+技术数据实证
  • 2025年11月门窗源头厂家TOP榜:折叠/静音/平开/智能/极窄推拉门窗厂家售后保障综合实力
  • 深入解析:Mac如何安装mysql和完全卸载mysql