Git基本操作
git 工作区、暂存区和版本库
工作区:就是你在电脑里能看到的目录。
暂存区:英文叫 stage 或 index。一般存放在 .git 目录下的 index 文件(.git/index)中,所以我们把暂存区有时也叫作索引(index)。
版本库:工作区有一个隐藏目录 .git,这个不算工作区,而是 Git 的版本库。
下面这个图展示了工作区、版本库中的暂存区和版本库之间的关系:

图中左侧为工作区,右侧为版本库。在版本库中标记为 “index” 的区域是暂存区(stage/index),标记为 “master” 的是 master 分支所代表的目录树。
图中我们可以看出此时 “HEAD” 实际是指向 master 分支的一个"游标"。所以图示的命令中出现 HEAD 的地方可以用 master 来替换。
图中的 objects 标识的区域为 Git 的对象库,实际位于 “.git/objects” 目录下,里面包含了创建的各种对象及内容。
当对工作区修改(或新增)的文件执行 git add 命令时,暂存区的目录树被更新,同时工作区修改(或新增)的文件内容被写入到对象库中的一个新的对象中,而该对象的ID被记录在暂存区的文件索引中。
当执行提交操作(git commit)时,暂存区的目录树写到版本库(对象库)中,master 分支会做相应的更新。即 master 指向的目录树就是提交时暂存区的目录树。
当执行 git reset HEAD 命令时,暂存区的目录树会被重写,被 master 分支指向的目录树所替换,但是工作区不受影响。
当执行 git rm --cached 命令时,会直接从暂存区删除文件,工作区则不做出改变。
当执行 git checkout . 或者 git checkout – 命令时,会用暂存区全部或指定的文件替换工作区的文件。这个操作很危险,会清除工作区中未添加到暂存区中的改动。
当执行 git checkout HEAD . 或者 git checkout HEAD 命令时,会用 HEAD 指向的 master 分支中的全部或者部分文件替换暂存区和以及工作区中的文件。这个命令也是极具危险性的,因为不但会清除工作区中未提交的改动,也会清除暂存区中未提交的改动。
git基本命令
1、文件夹初始化,将本地文件夹变成本地仓库,操作成功后会出现一个.git文件夹,但是此文件夹默认是隐藏的,需要打开“隐藏的项目”才能查看到,只有存在.git文件才能执行git相关的操作
$ git init
2、将内容添加到暂缓区
$ git add . # 将当前目录下所有新增和修改存至暂缓区,但不包括删除
$ git add -u # 将当前目录下所有修改和删除存至暂缓区,但不包括新增
$ git add -A # 缓存所有的改动
$ git add index.html # 添加具体的某一文件至暂缓区
$ git add *.js # 添加某一类型的文件至暂缓区
3、查看上次提交后是否又对文件进行再次修改
$ git status
4、比较文件的差异
$ git diff
5、查看Git的所有配置文件
$ git config --list
6、查看所有提交过的版本信息
$ git log
7、查看所有分支的所有操作记录,(包括已经被删除的 commit 记录和 reset 的操作)
$ git reflog
8、项目版本的回退,首先要查找到回退的版本号
$ git reset --hard xxxxxxx(回退的版本号)
9、删除某一个文件
$ git rm 文件名称
10、创建分支,默认分支为master
$ git branch 分支名称
11、查看分支
$ git branch
12、切换分支
$ git checkout 分支名称
13、克隆远程仓库的项目代码至本地
$ git clone 仓库地址
14、拉取代码
$ git pull
# 当运行结果出现Already up to date. 表示当前代码是最新的
15、提取代码
$ git push origin 分支名称
16、配置使Git显示颜色
$ git config --global color.ui true
git分支合并
1、假设现在在dev分支上,完成了项目的开发,需要将代码推送到远程仓库
$ git add .
$ git commit -m '提交时的备注信息'
$ git push -u origin dev
2、然后想要将dev分支上的内容合并到master分支上,首先需要切换到master分支上
$ git checkout master
3、为了保险起见,在切换到master分支上以后,先将master分支上的代码pull下来
$ git pull origin master
4、然后把dev分支上的代码合并到master分支上
$ git merge dev
5、合并之后,需要将master分支上的代码推送至远程仓库
$ git status // 查看合并后的状态
$ git push origin master
1万+

被折叠的 条评论
为什么被折叠?



