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