基础命令
git init
将该文件初始化为一个git仓库,同时自动创建第一个分支master
git add <filename>
将“修改”加到暂存区(Stage),可以添加多个,修改包括“新增、删除、改动”等变化
git commit -m "commit message"
一次性将暂存区的所有“修改”提交到当前分支中
git status
查看仓库当前状态
git diff
查看内容的变化
时光机
回退版本
git log
查看由近至远的提交记录,简化版本加上参数--pretty=online
git reset --hard <version>
回退到指定版本
方式一:用HEAD
表示指向最新版本的指针,HEAD^
表示上一个版本,HEAD^^
表示上上个版本,HEAD~100
表示上100个版本
方式二:可以用commit id来表示版本,只需要写前五六位即可
当找不到被回退的新版本,可以使用git reflog
来查找,其记录了每次操作
撤销修改
git checkout --filename
此处特指添加了参数--filename
场景一:文件修改后还未add,使用后从工作区删除修改,即git status
不会显示有修改
场景二:文件已add,还未commit,需要先使用git reset --hard HEAD <filename>
,撤销暂存区的修改,回到场景一,再操作
场景三:文件已commit,还未push,直接用git reset --hard <version>
回推到上一版本
删除文件
先把工作区的文件自行删除,然后执行git rm filename
,再commit
如果是误删,直接使用git checkout --filename
,其实checkout表示用版本库中的版本替换工作区的版本,无论是删除还是修改,都可以“一键还原”
远程仓库
git remote add origin git@github.com:Unintented/repo-name.git
关联一个远程仓库,默认名称叫做origin
,而该远程仓库的默认分支为master
git push -u origin master
第一次推送master
分支所有内容(其实是--set-upstream
的简写版),主要用来将当前本地分支与远程仓库origin
的master
分支关联,同时push
p.s. 与远程仓库进行关联失败,可以尝试更换ssh公钥
git push origin master
后续推送最新修改
git clone git@github.com:Unintented/repo-name.git
ssh方式克隆远程仓库,速度快
git remote -v
查看已添加的远程仓库
git branch -a
查看所有分支,红色表示远程分支
分支管理
创建与合并分支
一开始,master
分支是一条线,指向最新的提交,而HEAD
指向“当前”分支,可以来回在不同分支之间切换
新创建的分支(一个指针,比如dev
)初始指向最新提交,也就是master
指向的提交,当把HEAD
指向dev
时,表示当前分支在dev
上。
此后,修改与提交就是针对dev
分支进行的了,如新提交一次,dev
指针向前移一步,而master
指针不变
当在dev
上的工作完成后,就可以把dev
合并到master
上,最简单的情况就是直接将master
的指针指向dev
合并后,可以将dev
分支删除掉,也就是直接将dev
指针删除掉
git switch -c <name>
创建+切换分支
git branch <name>
创建分支
git switch <name>
切换分支
git branch
查看分支
git merge <name>
合并分支到当前分支
git branch -d <name>
删除分支
其他复杂操作可以直接使用例如git branch --help
的方式查看官方解释