创建版本库,在windows环境下,新建文件夹(D:\tools\JAVA\git\git-version),找到对应路径在cmd中执行git init命令,此时该文件夹下出现一个.git文件,它是用来跟踪管理版本库的,不能手动修改这个目录里面的文件,不然会把Git仓库给破坏了。
Git和其他版本控制系统如SVN的一个不同之处就是有暂存区的概念。Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD。在我们提交东西的时候是分两步
第一步是用git add把文件添加进去,实际上就是把文件修改添加到暂存区;
第二步是用git commit提交更改,实际上就是把暂存区的所有内容提交到当前分支。
在git-version下新建new.txt文件,文件内容随便写点什么,把文件先添加到文本库【git add new.txt】再进行提交【git commit -m '提交说明,增强阅读性'】。如果有多个文件需要提交可以先添加多次再一次提交
操作多次后可用命令 【git log】 显示从最近到最远的提交日志。HEAD表示当前版本,想要退回到上一版本为HEAD^,上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100。Git的版本回退速度非常快,因为Git在内部有个指向当前版本的HEAD指针,要退回到某个版本只是把指针移动。如果你退回到某一版本后发现操作错了的话可以查看【git reflog】命令,它用来记录每一次命令:或者在知道退回前的版本号的情况下,使用命令【git reset --hard commit_id】回到退回前的版本(commit_id即版本号)
git管理的是修改而不是文件,首先用命令【git status】查看工作区的内容是否有过修改,然后再new.txt文件上添加一些文字用【git add】添加到暂存区,再做一些修改,添加一些文字,此时再提交,如下:
此时发现第一次修改提交了第二次并没有提交上去,用【git diff HEAD -- new.txt】命令可以查看工作区和版本库里面最新版本的区别
要继续提交只需把第二次修改添加到暂存区再提交或者两次修改第一次只添加到暂存区不提交,第二次也添加到暂存区然后两次修改一起提交即:git add new.txt-->git commit -m '提示信息'完成第一次修改后的提交,第二次修改后再进行git add new.txt-->git commit -m '提示信息'。或者 第一次修改后 git add new.txt 第二次修改后 git add new.txt,再把两次添加一起提交 git commit -m '提示信息
当做了一些错误的操作想要撤销时,分三种情况,
1、当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout -- file。
2、当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令git reset HEAD ,就回到了1,第二步按1操作。
3:已经提交了不合适的修改到版本库但并没有提交到远程版本库中时,想要撤销本次提交可以退回上一版本
如果要删除某个文件(new.txt)先在本地进行删除或者用命令【rm new.txt】再【git status】查看现在可以继续删除也可以恢复,如果要删除的话执行命令【git rm new.txt】【git commit -m '提示信息'】此时是真正的删除,若要恢复则用命令【git checkout -- new.txt】。由此可以看出【git checkout --】其实是用版本库里的版本替换工作区的版本,无论工作区是修改还是删除,都可以“一键还原”。
网友评论