参考资料:廖雪峰中文网站
学习顺序:
git的基本简介就不写啦,从正文开始。
- 创建版本库
初始化git仓库,使用git init命令。
添加文件到git仓库,分两步:
第一步:git add <file>,注意可以添加多个文件
第二步:git commit -m "注释文字" ,完成。 - 时光穿梭机
git status 查看工作区的状态
若git status告诉你文件已被修改,使用git diff查看修改内容
- 版本回退
HEAD指向的版本就是当前的版本,所谓的版本回退,原 理就是使HEAD指向以前的版本 git reset --hard commit_id.
穿梭前,用git log可以查看提交的历史,以便确定要回退到哪个版本。
要重返未来,用git reflog查看命令历史,以便确定要回到未来哪个版本
为了简约,可以使用 git log --pretty=oneline。 -
工作区和暂存区
工作区:在电脑里能看到的目录,比如learngit文件夹。
版本库(Repository)
- 撤销修改
场景一:当改乱了工作区某个文件的内容,想直接丢弃 工作区的修改时,用命令行 git checkout -- file.
场景二:当改乱了工作区的某个文件的内容,还添加到了暂存区时,想丢弃修改,使用命令 git reset HEAD file, 就回到了场景1,第二步按场景1操作。
场景三:已经提交了不合适的修改到版本库时,想要撤销,参考上面版本回退。若推送到远程库,就木有办法了。 - 删除文件
git rm用于删除一个文件。如果一个文件已经被提交到版本库,那就不用担心误删,但是要小心,你只能恢复文件到最新版本,你会丢失最近提交后你修改的内容。
- 远程仓库
- 添加远程库
要关联一个远程库,使用git remote add origin git@server-name:path/repo-name.git;
关联后,使用命令git push -u origin master第一次推送master分支的所有内容;
此后,每次本地提交后,只要有必要,就可以使用命令git push origin master推送最新修改; - 从远程库克隆
要克隆一个仓库,首先必须知道仓库的地址,然后使用git clone命令克隆。
git支持多种协议,包括https,但通过ssh支持的原生git协议速度更快。
- 分支管理
- 创建与合并分支
查看分支:git branch
创建分支:git branch <name>
切换分支:git checkout <name>
创建+切换分支:git checkout -b <name>
合并某分支到当前分支:git merge <name>
删除分支:git branch -d <name> - 解决冲突
当git无法自动合并分支时,就必须首先解决冲突(手动选择)。解决冲突后,再提交,合并完成。
用git log --graph命令可以看到分支合并图。 - 多人协作
查看远程库信息,使用git remote -v;
本地新建的分支如果不推送到远程,对其他人就是不可见的;
从本地推送分支,使用git push origin branch-name,如果推送失败,先用git pull抓取远程的新提交;
从本地创建和远程分支对应的分支,使用git checkout -b branch -name origin/branch-name,本地和远程分支的名称最好一致;
建立本地分支和远程分支的关联,使用git branch --set-upstream branch-name origin/branch-name;
从远程抓取分支,使用git pull,如果有冲突,要先处理冲突。
PS:今天是还学会了使用了markdown了呢!!