Курс Python → Значения по умолчанию в Python
Значения по умолчанию в Python разделяются между объектами из-за того, что они создаются лишь однажды при определении функции. Это означает, что если значение по умолчанию является изменяемым объектом, таким как словарь, то все последующие вызовы функции будут использовать изменённый объект. Например, если у нас есть функция, которая принимает словарь в качестве значения по умолчанию, и мы изменяем этот словарь в одном вызове функции, то изменения будут сохранены для всех последующих вызовов.
С другой стороны, неизменяемые объекты, такие как числа, строки, кортежи и None, безопасны при изменении, так как они не могут быть изменены после создания. Поэтому значения по умолчанию, которые являются неизменяемыми объектами, будут оставаться неизменными для всех вызовов функции. Например, если значение по умолчанию — это число или строка, то оно не будет изменяться даже при изменении внутри функции.
Изменение изменяемых объектов, таких как словари, списки и экземпляры пользовательских классов, может привести к неожиданным последствиям. Поэтому при определении функций с изменяемыми значениями по умолчанию необходимо быть осторожным и учитывать, что изменения этих объектов будут видны для всех последующих вызовов функции.
def example_function(some_dict={}):
some_dict['key'] = 'value'
return some_dict
print(example_function()) # {'key': 'value'}
print(example_function()) # {'key': 'value'}
В данном примере функция example_function принимает словарь в качестве значения по умолчанию и добавляет в него пару ключ-значение. При вызове функции дважды мы видим, что изменения, внесенные в словарь, сохраняются для всех вызовов. Это происходит из-за того, что значение по умолчанию (пустой словарь) создается только один раз при определении функции и используется для всех вызовов.
Другие уроки курса "Python"
- Хеширование паролей с использованием salt
- Работа со строками в Python
- Генераторы данных
- Структура данных deque в Python
- Antigravity модуль
- Перехват исключений в Python
- Retrying в Python: повторные вызовы
- Работа с часовыми поясами в Python
- Повторение и перенос строки
- Аргументы *args и **kwargs
- Асинхронное выполнение задач в Python
- Декоратор total_ordering для сравнения объектов
- CSV строка разделение в Python
- Хешируемые ключи в Python
- Функция zip() в Python
- Объединение словарей в Python
- Метод append() для списка
- IPython и Jupyter Notebook: руководство
- Вычисление разности множеств в Python
- Основы Python
- Python enumerate() для работы с индексами
- Функции all() и any() в Python
- Проекты на Python
- Генерация случайных чисел в Python
- Переменные класса и экземпляра
- Операции со строками в Python
- Удаление элементов по срезу
- Использование html-скриптов в Jupyter Notebook
- Работа с каталогами в Python
- Оптимизация строк в Python
- Python 3.12: переиспользование кавычек
- Python Enumerate
- Библиотека Chartify: руководство
- Создание вкладок с TKinter
- UserList в Python: Описание и примеры использования
- Работа с массивами в Numpy
- Методы обработки строк в Python
- Замеры производительности в Python
- Python enumerate() функции
- Проверка запуска скрипта или импорта модуля
- Функция с **kwargs в Python
- Расчет времени выполнения
- Распаковка аргументов в Python
- ROT13 Шифр Цезаря в Python
- Отправка HTTP-запросов в Python
- Многоточие в Python















