
本文详解 python 函数间共享可变对象(如嵌套字典列表)的正确方式:通过返回值传递引用,避免作用域陷阱,确保 func2 能安全修改 func1 创建的数据结构。
在 Python 中,函数参数传递本质上是“对象引用的传递”。但初学者常误以为修改形参就能自动影响外部变量——尤其当函数内部重新赋值(如 my_list = [...])时,会断开与原始对象的连接,导致修改失效。关键在于区分重新赋值与就地修改。
✅ 正确做法:返回对象 + 显式传递引用
func1 应创建数据并返回它;func2 接收该引用并执行就地修改(如 name[0]['id'] += 1)。由于列表和字典是可变对象,func2 对其元素的修改会直接反映在原始对象上:
def func1(my_list, test1, test2):
# 创建新列表并返回 —— 不修改传入的 my_list(即使传了也忽略)
return [{'name': 'Saeed', 'id': 1}, {'name': 'David', 'id': 2}]
def func2(name):
# 直接修改传入列表的第一个字典的 'id' 字段(就地操作)
name[0]['id'] += 1
# 使用流程:获取返回值 → 传入另一函数
data = func1([], 1, 2) # data 指向新创建的列表
func2(data)
func2(data)
print(data) # 输出: [{'name': 'Saeed', 'id': 3}, {'name': 'David', 'id': 2}]⚠️ 常见错误与说明
- ❌ 错误写法:在 func1 中仅 my_list = [...] 而不 return,调用后 my_list 在函数外仍为空(原列表未被修改);
- ❌ 错误假设:认为 func2(name) 中的 name 自动关联 func1 的局部变量——实际无任何隐式链接;
- ✅ 关键原则:Python 没有“全局变量自动绑定”机制;跨函数共享数据必须显式传递(参数/返回值)或使用模块级变量(不推荐)。
? 进阶建议
- 若需多次复用同一数据,可考虑封装为类(class DataManager),将列表作为实例属性管理;
- 对不可变类型(如 int, str),必须用返回值更新(因无法就地修改);
- 使用 typing.List[dict] 添加类型提示,提升代码可维护性。
总之,清晰的职责划分(func1 负责构造,func2 负责变更)配合显式的引用传递,是 Python 函数协作的健壮实践。










