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
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!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

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

To download projects locally via Git, follow these steps: Install Git. Navigate to the project directory. cloning the remote repository using the following command: git clone https://github.com/username/repository-name.git

Git Commit is a command that records file changes to a Git repository to save a snapshot of the current state of the project. How to use it is as follows: Add changes to the temporary storage area Write a concise and informative submission message to save and exit the submission message to complete the submission optionally: Add a signature for the submission Use git log to view the submission content

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

Git code merge process: Pull the latest changes to avoid conflicts. Switch to the branch you want to merge. Initiate a merge, specifying the branch to merge. Resolve merge conflicts (if any). Staging and commit merge, providing commit message.

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.

When developing an e-commerce website, I encountered a difficult problem: How to achieve efficient search functions in large amounts of product data? Traditional database searches are inefficient and have poor user experience. After some research, I discovered the search engine Typesense and solved this problem through its official PHP client typesense/typesense-php, which greatly improved the search performance.

To delete a Git repository, follow these steps: Confirm the repository you want to delete. Local deletion of repository: Use the rm -rf command to delete its folder. Remotely delete a warehouse: Navigate to the warehouse settings, find the "Delete Warehouse" option, and confirm the operation.
