基础的直接学习廖雪峰的GIT教程,下面是进阶版的一些学习记录:
1. Git pull和Git fetch的区别
2. Git rebase和Git merge的区别
3. .Gitignore的作用和哪些路径应该写入.Gitignore
4. Git cherry-pick的作用
5. Git grep的作用
6. Git blame的作用
7. Git submodule和Git subtree的区别
8. Git里面的fast-forward是什么意思
9. 如何操作暂存区的文件
10. Git stash的作用
11. Git log和Git reflog的区别
12. 如何恢复Git reset丢失的版本
13. Git gc的作用
14. 如何把多个commit压缩成一个
15. Git revert和Git reset的区别
16. Git bisect的作用
17. Git里面有哪些hook
18. Git clone -b 有什么作用
19. Git 清除未跟踪的文件
20. Git log 命令支持的选项
21. Git branch --set-upstream-to参数
22. 删除远程分支
1、Git pull和Git fetch的区别
Git pull 可以自动合并相关的文档,Git fetch 则不会自动合并
我理解为当第一次下载Git资源的时候,以及需要手动合并文档时需要用到Git fetch。
2、Git merge 和 Git rebase 的区别
Git merge 对分支进行合并,并且记录merge commit的记录,如果希望合并能够展现出一个清晰平滑的日志则需要用到Git rebase,它能够从临时补丁中将冲突的分支更新为最新的分支,而不是记录为合并日志
3、.Gitignore的作用和哪些路径应该写入.Gitignore
它的作用是指定不需要添加到版本管理的某些文件或文件夹,一般由开发工具自动生成的文件或文件夹、或者本地的配置文件是不需要添加到版本管理中,比如node_modules、conf/locConf.js、.vscode等等
4、Git cherry-pick的作用
一般当版本落差比较大的时候,不同的分支会有比较多的冲突,比如2.0和3.0两个分支的冲突将非常麻烦,如果仅仅是需要合并部分的功能或者一步步进行合并则需要使用到Git cherry-pick,它可以将分支中某一个commit独立出来生成一个新的提交,然后再手工解决相应的冲突即可
5、Git grep的作用
grep适用于查找,仅仅只能用于查找而不能checkout或者archive。查找可以方便开发人员查找库里面的某个函数或者某个变量,比如说历史代码中某个函数被删除或者被重写了,可以通过grep在历史中找到这个函数的原始内容
6、Git blame的作用
blame会逐行显示文件,并在每一行的行首显示commit号,提交者,最早的提交日期,这个命令可以查找到某个文件的提交人修改人和提交时间和修改时间,精细到每一行都可以输出是哪一次的提交,对解决冲突有很大的帮助
7、Git submodule和Git subtree的区别
都属于模块化管理,submoudule属于引用,需要频繁的使用init和update来保证模块代码的最新版;subtree则直接下载所有的代码内容,同时在pull后直接拿到最新的代码,但是会占用空间。如果模块化的多个项目里,通过模块化管理实现双向或多向更新那么就high了
8、Git里面的fast-forward是什么意思
fast-forward 即快速推进,是指在merge分支的时候快速合并,当合并完成后不会保留分支的开发记录。
9、如何操作暂存区的文件
Git分为工作区、暂存区和版本库,对暂存区的文件的操作包括添加、回退和提交,当使用了add后,文件将被提交到暂存区。如果需要回退,则使用Git reset <commit id> <file>将文件回退,并且从暂存区中删除。当确定文件需要提交时,则使用Git commit 将文件提交,并且从暂存区中删除。
10、Git stash的作用
存储工作区,将当前工作区的所有修改都保护起来。然后通过Git stash pop恢复当前工作区。当在自己的开发分支工作的时候,突发需要急紧修改的BUG,需要切换到另一个分支去修改BUG。但是当前分支的工作还没有完成还不能提交代码,可以使用stash来保护当前工作区去修改BUG
11、Git log和Git reflog的区别
Git log 可以看到正式的版本日志,由开发人员回退版本的日志不会体现在log中, reflog则能够看到所有的版本日志包括(commit和reset)。当开发人员通过reset将版本回退后,又希望把回退的版本再恢复回来,但是已经丢失了commit-id,则可以通过reflog查看所有的操作日志,找回reset的commit-id进行恢复
12、如何恢复Git reset丢失的版本
通过reflog查看包括reset操作的所有log,然后通过日志中的commit-id进行恢复
13、Git gc的作用
gc garbage collect 垃圾回收,GIT会自动判断当前的仓库体积是否过大(松散对象过多),如果过大GIT会将GIT出现的松散对象打包至packfile的二进制节省空间来提高效率。
14、如何把多个commit压缩成一个
通过使用rebase命令来合并多个commit,使用的方法有两种
1、Git rebase -i HEAD
2、Git rebase -i commit-id
-i 表示当前的合并是一个交互式的操作,需要手动填写相应的命令。
15、Git revert和Git reset的区别
Git revert 是生成一个新的提交来撤销某次提交,此次提交之前的commit都会被保留
Git reset 是回到某次提交,提交及之前的commit都会被保留,但是此次之后的修改都会被退回到暂存区。
当使用reset后,需要找回被reset的commit时,则需要使用reflog来查找日志,如果一直使用revert来做回滚操作的话,则仅仅使用log来查找日志即可恢复之前撤销的操作
16、Git bisect的作用
通过二分法定位版本的错误,如果当前版本出现BUG错误,需要定位之前没有出现这个BUG的版本,可以先定位当前版本为bad
Git bisect start
Git bisectbad
然后编译前一个大的版本,检查是否有BUG,如果有则继续定位为bad
Git bisect bad
当编译并测试某一个版本没有BUG时,则定位为good
Git bisect goodv2.6
然后在bad和good两个版本中间,继续使用二分法来查找出现BUG的中间版本,从而定位到该BUG在哪个版本中出现
17、Git里面有哪些hook
18、Git clone -b有什么作用
当拿到GIT的URL时,需要在远程GIT库中直接获取分支中的代码则需要使用-b,比如需要获取develop的分支则使用 git clone -b develop gitxxxxx.git
19、 Git清除未跟踪的文件
git clean -f 清除文件, git clean -df 清除文件夹及文件
20、git log 命令支持的选项
-p 按补丁格式显示每个更新之间的差异。
--stat 显示每次更新的文件修改统计信息。
--shortstat 只显示 --stat 中最后的行数修改添加移除统计。
--name-only 仅在提交信息后显示已修改的文件清单。
--name-status 显示新增、修改、删除的文件清单。
--abbrev-commit 仅显示 SHA-1 的前几个字符,而非所有的 40 个字符。
--relative-date 使用较短的相对时间显示(比如,“2 weeks ago”)。
--graph 显示 ASCII 图形表示的分支合并历史。
--pretty 使用其他格式显示历史提交信息。可用的选项包括 oneline,short,full,fuller 和 format(后跟指定格式)。
--pretty=format 参数说明
%H 提交对象(commit)的完整哈希字串
%h 提交对象的简短哈希字串
%T 树对象(tree)的完整哈希字串
%t 树对象的简短哈希字串
%P 父对象(parent)的完整哈希字串
%p 父对象的简短哈希字串
%an 作者(author)的名字
%ae 作者的电子邮件地址
%ad 作者修订日期(可以用 -date= 选项定制格式)
%ar 作者修订日期,按多久以前的方式显示
%cn 提交者(committer)的名字
%ce 提交者的电子邮件地址
%cd 提交日期
%cr 提交日期,按多久以前的方式显示
%s 提交说明
常用的,输出自己的GIT日志,包含日期和说明,如下
#git log --pretty=format:"%cd %s" --graph
21.Git branch --set-upstream-to参数
当本地分支没有与线上的分支链接上的时候,每一次pull和push都需要明确写出远程分支的名称,如果需要链接上,则可以使用下面这样的命令
git branch --set-upstream-to=origin/远程分支名称 本地分支名称
22.删除远程分支
git push origin :branchName
网友评论