Какой вариант корректно избегает ловушки с изменяемым значением по умолчанию для списка?
A
def add(x, items=[]): items.append(x); return itemsB
def add(x, items=None): items = [] if items is None else items; items.append(x); return itemsC
def add(x, items=()): items.append(x); return itemsD
def add(x, items={}): items.append(x); return itemsПравильный ответ. Безопасный паттерн: ставить дефолт
None и создавать новый список внутри функции.Разбор
Изменяемые дефолты (список, словарь, множество) создаются один раз и переиспользуются. Чтобы избежать общих побочных эффектов между вызовами, обычно ставят items=None, а внутри делают инициализацию: items = [] if items is None else items. Тогда при каждом вызове без items создаётся новый список, и данные не «накапливаются» неожиданно.
Проверь себя · 1/3разбор после ответа
Есть функция
def power(x, exp=2): return x ** exp. Что вернет вызов power(3)?Ещё вопросы по теме «Функции и аргументы»
- Есть функция `def add(x, y): return x + y`. Что вернет вызов `add(2, 3)`?
- Дана функция `def f(a, b, c): return a * 100 + b * 10 + c`. Что вернет вызов `f(1, c=3, b=2)`?
- Есть функция `def power(x, exp=2): return x ** exp`. Что вернет вызов `power(3)`?
- Дана функция `def total(*args): return sum(args)`. Что вернет вызов `total(1, 2, 3)`?
- Дан код: `x = 10; def inc(): return x + 1`. Что вернёт вызов `inc()`?
- Все вопросы по «Функции и аргументы» →