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
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

百里 Jess

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值