1. 設置Alias
通過設置Alias可以簡化一些復雜的Git 命令。
舉幾個例子:
git status 可以簡寫成 git st
git pull --rebase 可以簡寫成git pr
...
設置git alias:
git config --global alias.pr 'pull --rebase'
顯示所有已設置的Alias
git config --get-regexp alias
PS. 所有的Alias都可以直接通過 .gitconfig 文件做增刪改查:
vi ~/.gitconfig
2. 代碼的同步
代碼下載
git clone [path-to github\gitlab] [folderName]
//可以通過folderName 指定文件夾名稱
代碼下拉
git pull --rebase
// 加rebase參數可以有效避免太多臨時分支的問題
PS. why pull rebase
代碼添加\移出待提交隊列
git add . //所有文件都添加
git add path-to-file1 path-to-file2 ... //添加單個文件
git reset . //移出所有文件
git add path-to-file1 path-to-file2 ... //移出單個文件
將待提交代碼提交到本地\撤銷本地提交
git commit -m "your comment"
git reset [commit id] // 你想退回到的目標提交的id
將本地的commit推到服務端
git push
git revert [commit id]// push 上去的東西是無法徹底刪掉的,revert只是重新提交一個撤銷某次提交的請求
一次完整的提交代碼流程:
git add . // 篩選要提交的文件
git commit -m "your comment"
git pull --rebase // 下拉代碼防止沖突
// 如果有沖突,解決沖突
git push
// 如果是git add . ,那么前兩步可以簡寫成一步
git commit -am "your comment"
查看本地修改
git diff [filename] //查看未進入待提交隊列的修改, 不填filename則是所有文件
git diff --cached //查看已進入待提交隊列的修改
還原某個修改過文件
git checkout . //還原所有
git checkout [path-to-file1] [path-to-file2]...
查看提交記錄
git log
branch相關
查看分支
git branch //本地分支
git branch -r //遠程分支
git branch -a //所有分支
創建本地分支
git checkout -b [branch-name]
本地分支推到服務端
git push -u origin [branch-name]
//不加-u 需要額外綁定兩個分支的關系
git push origin [branch-name-remote]
git branch --set-upstream [branch-name-local] origin/[branch-name-remote]
切換分支
git checkout [local branch]
刪除分支
//刪除本地分支,要求本地分支已經merge到upstream或者HEAD
git branch -d [branch-name]
//強制刪除本地分支,不管你merge沒有
git branch -D [branch-name]
//刪除遠程分支
git push origin :[remote-branch-name]
PS. 刪除分支可以參考男男的 git 刪除分支
將某個分支merge到當前分支
git merge [other-branch]
將其他分支的某些提交merge到當前分支
git cherry-pick [commit-id-1] [commit-id-2] ....
tag 相關
查看所有tag
git tag
本地打tag
//最簡單方式,commitID 不填默認為當前commit
git tag [tag-name] [commit-id]
//比較合理的用法
git tag -fa [tag-name] -m "your comment"
// -f 表示覆蓋已有的同名標簽
// -a 表示是annotated tag, 可以加注釋
tag 同步到服務端
git push --tags // 只push tag
git push --all // push 所有,包括代碼和tag
刪除本地tag
git tag -d [tag-name]
刪除tag
git push origin :refs/tags/<tagname> //按名稱刪除所有分支中的tag
submodule 相關
添加submodule
git submodule add [submodule-git-path] [folderName]
更新submodule到主工程指定版本
git submodule update --init
其他操作
使用stash緩存
git stash [name]// 有些時候需要先git add 把沒在source control下的東西加進來
git stash pop
git stash drop
git stash list
git stash clear
查看代碼地址
git remote -v
[有待驗證...]
大招-還原所有本地未提交的修改(撤銷已提交的本地修改參考git reset)
git checkout HEAD --force
Fork 下的工程,需要fetch操作的參考 fork