返回None还是空集合?防御式编程的关键细节

我们来做一个假设,假设你有一个函数用于查找数据库中的某个集合结果,当查不到数据时,应该返回什么?

错误用法:

复制代码
def get_users(department):
    # 查不到返回 None
    if department == "财务":
        return None
    return ["张三", "李四"]

正确用法:

复制代码
def get_users(department):
    if department == "财务":
        return []
    return ["张三", "李四"]

返回 [](空集合)而不是 None 能确保调用者在不判断的情况下直接使用:

复制代码
for user in get_users("财务"):

    print(user)  # 不会报错

这在写 API SDK、数据接口、中间层函数时尤其重要。减少调用方的防御代码,是良好接口设计的关键。

可能有朋友要问:为什么空集合更好?有以下几个大致的原因:

  • 遵循最小意外原则:空集合是合法的可迭代对象
  • 避免 NoneType 错误:最常见的 Python 运行时错误之一
  • 简化调用逻辑:无需前置判空检查
  • 类型一致性:保持返回类型稳定(list → list)

那么何时该返回 None?通常在下面三种情况下:

  • 操作失败且无合理默认值时
  • 需要区分"无结果"和"错误"时
  • 函数名暗示可能返回 None
相关推荐
迈巴赫车主2 小时前
蓝桥杯3500阶乘求和java
java·开发语言·数据结构·职场和发展·蓝桥杯
小菜鸡桃蛋狗2 小时前
C++——string(上)
开发语言·c++
李昊哲小课2 小时前
Python办公自动化教程 - 第5章 图表创建 - 让数据可视化
python·信息可视化·数据分析·数据可视化·openpyxl
chushiyunen2 小时前
python pygame实现贪食蛇
开发语言·python·pygame
Dream of maid2 小时前
Python-基础2(流程控制)
python
身如柳絮随风扬3 小时前
Lambda、方法引用与Stream流完全指南
java·开发语言
jinanwuhuaguo3 小时前
人工智能的进化阶梯:AI、ANI、AGI与ASI的核心区别与深度剖析
开发语言·人工智能·agi·openclaw
清空mega3 小时前
C++中关于数学的一些语法回忆(2)
开发语言·c++·算法
Mr_Xuhhh4 小时前
从理论到实践:深入理解算法的时间与空间复杂度
java·开发语言·算法