Временное сохранение изменений в Git

Git Stash – это инструмент для временного сохранения изменений в репозитории. Он позволяет отложить текущую работу и переключиться на другую задачу без необходимости коммита незавершенного кода. Принцип работы основан на стеке, где изменения сохраняются и извлекаются в порядке LIFO (Last In, First Out).
Временное сохранение изменений в Git
Изображение носит иллюстративный характер

Для сохранения изменений используется команда git stash. По умолчанию сохраняются только отслеживаемые изменения. Для сохранения неотслеживаемых файлов используется флаг -u (или --include-untracked). Список сохраненных изменений можно просмотреть командой git stash list, каждая запись содержит имя, ветку и описание коммита, на котором основано сохранение.

Возврат к сохраненным изменениям осуществляется командами git stash pop и git stash apply. Первая команда применяет изменения и удаляет их из стека, вторая – только применяет, оставляя в стеке. Для удаления отдельных или всех сохранений используются git stash drop и git stash clear соответственно.

Кроме того, можно создать новую ветку на основе точки сохранения, используя команду git stash branch <branch_name> [<stash_name>]. Это извлекает изменения и создает новую ветку, делая дальнейшую работу более гибкой. Стоит использовать Git Stash умеренно, как временное решение и не забывать делать информативные описания сохранений. Также стоит изучить полезный флаг --autostash у git rebase и не хранить изменения слишком долго.


Новое на сайте