search
HomeDevelopment ToolsgitDetailed explanation of the temporary storage operation of 'git stash'

Detailed explanation of the temporary storage operation of 'git stash'

Why we need it

Not allowed Needless to say, when I learned about this command and when I used it later, I loved this command so much because it is so easy to use.

Let me tell you about the scenario where I used this command:

At this time, I was in the feature_666 branch, and I was very focused and focused on implementing a feature 666 module. I could write code like a flying keyboard~ ~~
Then at this time, the customer reported a bug, which was very serious and must be solved immediately, with a priority of 0! ! !
So, I need to go to the release branch to checkout the new branch to work, but what should I do if the 666 function is not completed yet?
At this time I faced a multiple-choice question:
A: Switch after submission, the code is saved to branch feature_666, but a meaningless submission is generated
B: Switch directly without submitting, but this option is not available at all Will choose.

Isn’t it difficult to choose? At this time, don’t forget that there is option C!

C: Use git stash to store the current modification (uncommitted code) in the cache, switch branches to modify the bug, and then come back and take it out through git stash pop.

1. Temporary storage operation

#查看当前状态
git status 
#如果有修改,添加修改文件
git add .
#暂存操作
git stash save '本次暂存的标识名字'

2. View the current temporary records

#查看记录
git stash list

Where are the modifications stored?

When we use git init to add version control to the project, it will be in A .git hidden folder is generated under the project path. .git stores all information for version management.
.git/refs/stash stores the node pointer corresponding to the last stash

Similarly, you can see all our stash record information in .git/log/refs/stash

The situation of storing multiple stash

ok, let’s try to modify the file, and then use git stash again. At this time we have two temporary modifications, so what? Check it out?

git stash list //View all temporary modification records in the temporary storage area

If you execute git stash twice without committing it, you cannot accurately distinguish the specific modifications of the two stashes. What content, used in this way, makes Git appear great? It is not smart at all, how could it be possible! .

So, in this case, it is obviously very important to give the stash stored modifications a name, as follows:

git stash save <message>

3. Restore the temporary work

'The pop command restores. After the restore, the temporary storage area will delete the current record'

#恢复指定的暂存工作, 暂存记录保存在list内,需要通过list索引index取出恢复
git stash pop stash@{index}

'The apply command restores. After the restore, the temporary storage area The current record will be retained'

#恢复指定的暂存工作, 暂存记录保存在list内,需要通过list索引index取出恢复
git stash apply stash@{index}

4. Delete temporary storage
##

#删除某个暂存, 暂存记录保存在list内,需要通过list索引index取出恢复
git stash drop stash@{index}
#删除全部暂存
git stash clear

Recommended tutorial: "

Git Tutorial

The above is the detailed content of Detailed explanation of the temporary storage operation of 'git stash'. For more information, please follow other related articles on the PHP Chinese website!

Statement
This article is reproduced at:jb51. If there is any infringement, please contact admin@php.cn delete
Git and GitHub: Essential Tools for DevelopersGit and GitHub: Essential Tools for DevelopersApr 19, 2025 am 12:17 AM

Git and GitHub are essential tools for modern developers. 1. Use Git for version control: create branches for parallel development, merge branches, and roll back errors. 2. Use GitHub for team collaboration: code review through PullRequest to resolve merge conflicts. 3. Practical tips and best practices: submit regularly, submit messages clearly, use .gitignore, and back up the code base regularly.

Git and GitHub: Their Relationship ExplainedGit and GitHub: Their Relationship ExplainedApr 18, 2025 am 12:03 AM

Git and GitHub are not the same thing: Git is a distributed version control system, and GitHub is an online platform based on Git. Git helps developers manage code versions and achieve collaboration through branching, merge and other functions; GitHub provides code hosting, review, problem management and social interaction functions, enhancing Git's collaboration capabilities.

What do you need to set after downloading GitWhat do you need to set after downloading GitApr 17, 2025 pm 04:57 PM

After installing Git, in order to use more efficiently, the following settings are required: Set user information (name and mailbox) Select text editor Set external merge tool Generate SSH key settings Ignore file mode

What to do if the git download is not activeWhat to do if the git download is not activeApr 17, 2025 pm 04:54 PM

Resolve: When Git download speed is slow, you can take the following steps: Check the network connection and try to switch the connection method. Optimize Git configuration: Increase the POST buffer size (git config --global http.postBuffer 524288000), and reduce the low-speed limit (git config --global http.lowSpeedLimit 1000). Use a Git proxy (such as git-proxy or git-lfs-proxy). Try using a different Git client (such as Sourcetree or Github Desktop). Check for fire protection

Why is git downloading so slowWhy is git downloading so slowApr 17, 2025 pm 04:51 PM

Causes of slow Git downloads include poor network connections, Git server problems, large files or large submissions, Git configuration issues, insufficient computer resources, and other factors such as malware. Workarounds include improving network connectivity, adjusting firewall settings, avoiding downloading unnecessary files or submissions, optimizing Git configuration, providing adequate computer resources, and scanning and removing malware.

How to update local code in gitHow to update local code in gitApr 17, 2025 pm 04:48 PM

How to update local Git code? Use git fetch to pull the latest changes from the remote repository. Merge remote changes to the local branch using git merge origin/<remote branch name>. Resolve conflicts arising from mergers. Use git commit -m "Merge branch <Remote branch name>" to submit merge changes and apply updates.

How to update code in gitHow to update code in gitApr 17, 2025 pm 04:45 PM

Steps to update git code: Check out code: git clone https://github.com/username/repo.git Get the latest changes: git fetch merge changes: git merge origin/master push changes (optional): git push origin master

How to delete branches of gitHow to delete branches of gitApr 17, 2025 pm 04:42 PM

You can delete a Git branch through the following steps: 1. Delete the local branch: Use the git branch -d <branch-name> command; 2. Delete the remote branch: Use the git push <remote-name> --delete <branch-name> command; 3. Protected branch: Use git config branch. <branch-name>.protected true to add the protection branch settings.

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Tools

Dreamweaver Mac version

Dreamweaver Mac version

Visual web development tools

mPDF

mPDF

mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

WebStorm Mac version

WebStorm Mac version

Useful JavaScript development tools

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.