主要
基础篇
1: Git Commit
使用两次git commit进行两次提交
data:image/s3,"s3://crabby-images/ed504/ed5043895ccd0c61219df58a0f709f9fa869013c" alt="在这里插入图片描述"
2: Git Branch
git branch <分支名> ---- 创建分支 git checkout <分支名> ---- 切换到分支 git checkout -b <分支名> ---- 创建并切换到分支 data:image/s3,"s3://crabby-images/039fb/039fbd2fc2361df1babfae9bd34dd657e0b60701" alt="在这里插入图片描述"
3: Git Merge
(1)用 git checkout -b bugFix 创建并转到新分支bugFix (2)用 git commit 进行C2的提交 (3)用 git checkout main 重新回到main (4)用 git commit 进行C3的提交 (5)用 git merge bugfix 进行合并bugFix和main的C4的提交 data:image/s3,"s3://crabby-images/e13bd/e13bd463d59acec633226375ff2f51b83f7f1fd8" alt="在这里插入图片描述"
4: Git Rebase
(1)用 git checkout -b bugFix 创建并转到新分支bugFix (2)用 git commit 进行C2的提交 (3)用 git checkout main 重新回到main (4)用 git commit 进行C3的提交 (5)用 git checkout bugFix 重新回到bugFix (6)用 git rebase main 从C3创建C2的副本 data:image/s3,"s3://crabby-images/82094/82094e4ac623f08ffa50bfdec99140e25a3222e5" alt="在这里插入图片描述"
高级篇
1: 分离HEAD
HEAD 通常情况下是指向分支名的(如 bugFix), 分离的 HEAD 就是让其指向了某个具体的提交记录而不是分支名 通过哈希值指定提交记录。每个提交记录的哈希值显示在代表提交记录的圆圈中。
这里使用 git checkout C4 便能够使HEAD指向C4 data:image/s3,"s3://crabby-images/19f55/19f559b6e9e4aed4b72d4e3a28dc6221171797cf" alt="在这里插入图片描述"
2: 相对引用(^)
<节点>^可以指向这一节点的上一节点 所以这里用 git checkout bugFix^ 指向C3 data:image/s3,"s3://crabby-images/5bb27/5bb279bdf681eeecaa472bf63d59a7be14df57f4" alt="在这里插入图片描述"
3: 相对引用(~)
<节点>~num可以指向这一节点的上num节点 (1)用 git branch -f main C6 直接引用提交C6,强制main指向C6 (2)用 git checkout bugFix~2 将HEAD通过相对引用指向C1 (3)用 git branch -f bugFix HEAD^ 将bugFix分支通过相对引用指向C0 data:image/s3,"s3://crabby-images/4fbce/4fbcea3274562b6e9df124729c7327c6390ad335" alt="请添加图片描述"
4:撤销变更
(1)用 git reset HEAD~1 对本地的local分支操作,撤销到上一级 (2)用 git checkout pushed 使HEAD移到pushed处 (3)用 git revert HEAD 对远端的pushed进行操作,生成与C1相同的提交来撤销C2 data:image/s3,"s3://crabby-images/adad8/adad84d0831877be487da7afc716f827333582c2" alt="在这里插入图片描述"
移动提交记录
1: Git Cherry-pick
用 git cherry-pick C3 C4 C7 将C3、C4、C7复制到当前main的分支下 data:image/s3,"s3://crabby-images/8b587/8b587087a437fe6cfc46320f2a0a1a72c483a865" alt="在这里插入图片描述"
2: 交互式 rebase
用 git rebase -i HEAD~4 进入到交互式页面,选择删除C2,调整C3、C4、C5的顺序 data:image/s3,"s3://crabby-images/b2a5d/b2a5d3b5d2f0cb253f9bb642b748829ed3caad28" alt="在这里插入图片描述"
杂项
1: 只取一个提交记录
用 git cherry-pick C4 只取C4提交记录放在C1下 data:image/s3,"s3://crabby-images/60935/60935deec96236068dae49d376b11c0a9687b874" alt="在这里插入图片描述"
2: 提交的技巧 #1
(1)用 git rebase -i HEAD~2 对C2、C3进行重新排序,便于对C2操作 (2)用 git commit --amend 对C2修改,生成C2’’ (3)用 git rebase -i HEAD~2 对C2’'、C3再次排序 (4)用 git brance -f main HEAD 强制将main分支移到HEAD处 data:image/s3,"s3://crabby-images/07709/077096df2585d27f91d97f9e3ef46bf78305743f" alt="在这里插入图片描述"
3: 提交的技巧 #2
(1)用 git checkout main 将HEAD移到main分支处 (2)用 git cherry-pick C2 复制C2生成C2’ (3)用 git commit --amend 对C2’修改,生成C2’‘’ (4)用 git cherry-pick C3 复制C3生成C3’ data:image/s3,"s3://crabby-images/c6a21/c6a215fbd1beb35e8c5d007941a67e3e1902089e" alt="在这里插入图片描述"
4: Git Tags
(1)用 git tag v0 C1 在C1建立锚点v0 (2)用 git tag v1 C2 在C2建立锚点v1 (3)用 git checkout v1 将HEAD移到v1节点 data:image/s3,"s3://crabby-images/7701a/7701ae326714879678c53100fc929fa2e1be0e9e" alt="在这里插入图片描述"
5: Git Describe
git describe <ref> <ref> 可以是任何能被 Git 识别成提交记录的引用
输出的结果是这样的:<tag>_<numCommits>_g<hash> tag 表示的是离 ref 最近的标签, numCommits 是表示这个 ref 与 tag 相差有多少个提交记录, hash 表示的是所给定的 ref 所表示的提交记录哈希值的前几位
高级话题
1: 多次 Rebase
(1)用 git rebase main bugFix 将bugFix和main合并 (2)用 git rebase bugFix side 将bugFix和side合并 (3)用 git rebase side another 将side和another合并 (4)用 git rebase another main 将another和main合并 data:image/s3,"s3://crabby-images/a0824/a08245d681bdec117670fa2d9b64cf0283fb182d" alt="在这里插入图片描述"
2: 两个父节点
用 git branch -f bugWork HEAD~1^2~1 创建分支bugWork,并且移动到HEAD上一个节点的第二个父节点的上一个节点 data:image/s3,"s3://crabby-images/bd30e/bd30e83f4450dabb5d56e462aa5d652e1c28f9d4" alt="在这里插入图片描述"
3: 纠缠不清的分支
(1)用 git checkout one 选中one分支 (2)用 git cherry-pick C4 C3 C2 复制节点 (3)用 git checkout two 选中two分支 (4)用 git cherry-pick C5 C4 C3 C2 复制节点 (5)用 git branch -f three C2 强制移动three分支 data:image/s3,"s3://crabby-images/05100/051004331eb9f97f0d585b1695366004c5d2e653" alt="在这里插入图片描述"
远程仓库
Push & Pull —— Git 远程仓库!
1: Git Clone
用 git clone 建立虚线的远程仓库 data:image/s3,"s3://crabby-images/ddcd7/ddcd7ec7468ce4be00ba6ac8c68c8f3c03f5c440" alt="在这里插入图片描述"
2: 远程分支
操作本地的分支时,不会对远程分支产生影响 远程分支的前面的 o/ 是什么意思,大多数的开发人员会将它们主要的远程仓库命名为 origin data:image/s3,"s3://crabby-images/a0a2e/a0a2e9e177ba88a4ae1f7a866e76bd3ba3518e6d" alt="在这里插入图片描述"
3: Git Fetch
git fetch 完成了仅有的但是很重要的两步:
- 从远程仓库下载本地仓库中缺失的提交记录
- 更新远程分支指针(如 o/main)
git fetch 实际上将本地仓库中的远程分支更新成了远程仓库相应分支最新的状态。 但是对本地的仓库不会产生影响,不会移动main分支 data:image/s3,"s3://crabby-images/9c381/9c381d6eb8be682afb366257e7769b00d694cbdb" alt="在这里插入图片描述"
4: Git Pull
git pull 命令相当于git fetch + git merge,即下载远程分支的同时,还将其与本地分支进行了合并 data:image/s3,"s3://crabby-images/6d9da/6d9da82140996b53baa30e3f3204df0ba979aea7" alt="在这里插入图片描述"
5: 模拟团队合作
(1)用 git clone 建立远程仓库 (2)用 git fakeTeamwork 2 在远程建立C2、C3提交 (3)用 git commit 提交C4 (4)用 git pull 下载远程分支并整合main data:image/s3,"s3://crabby-images/0fa0a/0fa0a129e0b3b78a09c346fc3e92585ade24a270" alt="在这里插入图片描述"
6: Git Push
(1)用 git commit 创建C2 (2)用 git commit 创建C3 (3)用 git push 将本地分支送到远程分支 data:image/s3,"s3://crabby-images/4255a/4255aa32e63ade375c90f30ac8df0e22a194d706" alt="在这里插入图片描述"
7: 偏离的提交历史
(1)用 git clone 创建远程仓库 (2)用 git fakeTeamwork 进行远程提交 (3)用 git commit 进行本地提交 (4)用 git pull --rebase 进行远程仓库的rebase下载 (5)用 git push 将本地仓库提交到远程仓库 data:image/s3,"s3://crabby-images/32f69/32f6939047f2bca8e18f7cda77265ebcfa0b7149" alt="在这里插入图片描述"
8: 锁定的Main(Locked Main)
(1)用 git checkout -b feature 创建并选中feature (2)用 git push 将本地仓库上传至远程仓库 (3)用 git branch -f main C1 强制移动main分支到C1 data:image/s3,"s3://crabby-images/9cbee/9cbee2a7924ff08b9c97f2623d9e649cf113d3c3" alt="在这里插入图片描述"
关于 origin 和它的周边 —— Git 远程仓库高级操作
1: 推送主分支
(1)用 git fetch 先下载远程仓库的分支 (2)用 git rebase o/main side1 (3)用 git rebase side1 side2 (4)用 git rebase side2 side3 (5)用 git rebase side3 main (6)用 git push 将本地重新调整的分支推送到远程仓库 data:image/s3,"s3://crabby-images/36a77/36a77c12d9c26bb081dd1b83e5e9f7e3114a285b" alt="在这里插入图片描述"
2: 合并远程仓库
(1)用 git checkout main (2)用 git pull (3)用 git merge side1 (4)用 git merge side2 (5)用 git merge side3 (6)用 git push data:image/s3,"s3://crabby-images/77ec7/77ec7f7c7f2fd75c72b8d4961bc96e62f73cde40" alt="在这里插入图片描述"
3: 远程追踪
4: Git push 的参数
5: Git push 的参数 2
6: Git fetch 的参数
7: 没有 source 的 source
8: Git pull 的参数
|