1:git status命令查看仓库当前的状态
2:git dif就是查看被修改的内容
3:git init把当前目录变成Git可以管理的仓库
4:git add【文件名】告诉Git,把文件添加到仓库
5:git commit [-m "注释"]告诉Git,把文件提交到仓库
6:git log显示从最近到最远的提交日志
7:首先,Git必须知道当前版本是哪个版本,在Git中,用HEAD表示当前版本,也就是最新的提交1094adb...(注意我的提交ID和你的肯定不一样),上一个版本就是HEAD^,上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100。
如:$ git reset--hard HEAD^
8:Git提供了一个命令git reflog用来记录你的每一次命令id,以便确定要回到未来的哪个版本:如
$git reflog
e475afcHEAD@{1}:reset:movingtoHEAD^1094adb(HEAD->master)HEAD
@{2}:commit:appendGPLe475afcHEAD
@{3}:commit:adddistributedeaadf4eHEAD
@{4}:commit(initial):wroteareadmefile
9:场景1:当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout -- file。
场景2:当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令git reset HEAD <file>,就回到了场景1,第二步按场景1操作。
10:删除工作区文件:rm 【文件名】命令删,确实要从版本库(git add后)中删除该文件,那就用命令git rm删掉,并且git commit。命令git rm用于删除一个文件。如果一个文件已经被提交到版本库,那么你永远不用担心误删,但是要小心,你只能恢复文件到最新版本,你会丢失最近一次提交后你修改的内容
///////////////////////////////////////////////////////////////////////////////////////////////////
11:添加远程库:
a:要关联一个远程库,使用命令git remote add origin git@github-name:path/repo-name.git(ssh协议)( git remote add origin https://github.com/Liangfenkai/learngit.git(https协议克隆));
b:关联后,使用命令git push -u origin master第一次推送master分支的所有内容;
c:此后,每次本地提交后,只要有必要,就可以使用命令git push origin master推送最新修改;
分布式版本系统的最大好处之一是在本地工作完全不需要考虑远程库的存在,也就是有没有联网都可以正常工作,而SVN在没有联网的时候是拒绝干活的!当有网络的时候,再把本地提交推送一下就完成了同步,真是太方便了!
12:从远程库克隆:git clone git@github.com:Liangfenkai/gitskills.git(ssh协议)( git clone https://github.com:/Liangfenkai/learngit.git(https协议克隆))
///////////////////////////////////////////////////////////////////////////////////////////////
13:查看分支:git branch
14:创建并切换分支:git checkout -b dev(等价于这两条指令:1:git branch dev(创建分支)。2:git checkout dev。(切换分支:git switch dev))//创建并切换分支可用:(git switch -c dev)
15:合并分支:git merge [分支名](eg:git merge dev)
16:删除分支:git branch -d [分支名](eg: git branch -d dev)
17:解决合并冲突:
18:如果要丢弃一个没有被合并过的分支,可以通过git branch -D <name>强行删除。
9:工作区和暂存区