git总结

git 中文件有三种状态:
ignore
tracked
untracked
文件有三个位置:
工作目录
暂存区
仓库中

push的是仓库中的代码,即使工作目录中的代码修改了但是没有add和commit,仓库中的代码也是不会变的,push的时候也不会受影响。

创建新分支,删除分支

创建并切换到新分支

  1. git branch branchname
    git checkout branchname
  2. git checkout -b newBranch

删除分支

  1. (本地)git branch -d branchname
  2. (远端)git push origin –delete branchname

添加文件到暂存区和取消添加

添加 git add . 或者 git add filename(文件名之间可以是空格隔开来添加多个文件) 或者 git add 文件夹

撤销添加:git reset HEAD filename

提交文件到仓库:
git commit -m “说明”
修改最新的提交
git commit –amend

暂存区中的文件覆盖工作目录中的文件

git checkout – filename

代码回滚:

git reset commit_id

撤销某次提交

git revert commit_id

将远端代码拉取到本地和某分支合并

git pull origin 远端分支:本地分支

将本地代码推送到远端和某分支合并

git push origin 本地分支:远端分支

将远端某分支拉取到本地

git fetch origin branchname

合并分支到当前分支

git rebase 分支名
git merge 分支名

查看文件状态

git status

查看提交日志

git log

想要切换分支但又不想commit当前分支的代码

git stash
git checkout 分支名 (接着是在当前分支的一些操作)
git checkout 原分支
git stash pop (原来的修改代码就回来了)

删除文件

  • 如何从仓库中和工作目录中删除一个文件??
    git rm 文件名
  • 只从暂存区删除文件
    git rm –cached 文件名:
  • git rm -r 文件夹/ :删除文件夹

查看工作目录相对索引区文件的修改??

git diff filename

通过手动的delete键在工作目录中删除文件

  1. 再使用一次 git rm 文件名
  2. 执行指令 git add -A .或者是git add -all .(注意一定要有一个“.”),就会将不存在的文件记录在文档库中,接着执行git commit ,就会从文档库删除这些文件。

总结:git revert 可以用在公共分支上,git reset 应该用在私有分支上。

合并代码的过程???
第一:有人发出合并请求
第二:有人对代码进行审查
第三:有人来执行合并操作

origin是什么意思??
git会自动把远程仓库的名字命为origin,使用git remote -v 可以看到origin指的地址是什么。

HEAD是什么??
可以看做是一个指针,始终指向当前分支,当前分支对应着最新一次提交的commit hash。

查看本地所有分支???
git branch -a

查看远程仓库所有分支??
git branch -r

新切一个分支????
git checkout -b newbranch

切换分支?
git checkout branch

将一个分支(一般是本地分支)合并到当前分支???
git rebase 分支名

怎么将远程仓库中的代码搞到本地来??
git clone

把一个分支的修改合并到当前分支
取回所有分支的更新:git fetch
取回指定分支的更新:git fetch origin 分支名 取回后就会在本地新建一个同名分支

git log可以看到什么??
谁在什么时间做了一次提交,对代码做出改动的说明是什么。
谁在什么时间对代码做了一次合并,合并了哪几次提交??
(如果有bug,那么让人进行修复之后切一个分支(checkout -b)做一次提交(commit),让人进行合并(merge)之后,其他人拉取(fetch)远端的指定分支,然后合并(rebase)到自己本地当前的分支)

push

把本地分支推送到远程主机的分支??
git push origin local:remote
可以省略远程分支名
git push origin local 将本地分支推送到与之存在追踪关系的分支(通常就是同名分支)
在git clone的时候,所有本地分支默认与远程主机的同名分支,建立追踪关系,
当前分支与远程分支存在追踪关系
git push origin
当前分支只有一个追踪分支
git push

pull

把远程分支取回本地并合并指定分支??
git pull origin 远程分支:本地分支
把远程分支取回本地并合并到当前分支??
git pull origin 远程分支
把远程和当前分支存在追踪关系的分支和当前分支进行合并
git pull

将指定分支合并到当前分支??
git merge branchname

查看所有的储藏列表??
git stash list

为什么要使用git stash??
当想要pull最新代码的时候会提示要先commit,这个时候如果不想commit,就可以执行
git stash
git pull
git stash pop

git stash 存储当前工作目录中的代码
git stash pop 应用最近一次存储的代码

如何提交一个文件??
git commit -m “描述信息”
将文件修改添加到索引??
git add filename
撤销对未放入索引区文件的修改?
git checkout filename

如何在别人的分支上面继续开发??
别人执行一次git commit
然后git fetch origin 分支名,然后git checkout 分支名,这样代码就和别人的代码一样了,可以在别人的基础上继续开发。
将工作目录中的所有变化提交到暂存区(包括修改和新加文件)?
git add .
–all参数全名 -A参数简写

git checkout – filename
用暂存区中filename文件来覆盖工作区中的filename文件。相当于取消自上次执行git add filename以来(如果执行过)的本地修改。

merge的原理??
rebase的原理??
1.版本1、版本3、版本6的 sha-1 值完全相同,这种情况表明没有冲突
2.版本3或6至少一个与版本1状态相同(指的是sha-1值相同或都不存在),这种情况可以自动合并。比如1中存在一个文件,在3中没有对该3.文件进行修改,而6中删除了这个文件,则以6为准就可以了
版本3或版本6都与版本1的状态不同,情况复杂一些,自动合并策略很难生效,需要手动解决。我们来看一下这种状态的定义。

将文件add到了暂存区中怎么取消操作??
git reset HEAD filename(其中filename可以写多个文件,文件之间用空格隔开,在add的时候也可以用这个方式)

提交之后reset操作??
git reset commit_id 会将仓库中的代码和暂存区中的代码一起回滚到那次提交之后的代码。工作目录中的代码则是自己操作过的代码。

在本次提交之后发现有些文件该提交却没有提交如何重新提交?
git add filename
git commit –amend(修订) (会弹出一个vim编辑器进行编辑提交的信息)
编辑完成后按esc然后输入
:wq就可以退出编辑。

回退到某个版本??
git reset 057d
向前回退几个版本?
git reset HESD~2/3/4··
撤销某次操作但是不影响此次操作前后的提交??
git revert commit_id/HEAD^/HEAD~1

执行commit操作后工作目录中的文件的名字颜色就会发生改变。如果只是add文件的颜色是不会发生改变的。

vim中在没有进入编辑模式之前,按下I,O就能进入编辑状态,区别是按下O会进入下一行编辑。按下esc则退出编辑状态。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,718评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,683评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,207评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,755评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,862评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,050评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,136评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,882评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,330评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,651评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,789评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,477评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,135评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,864评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,099评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,598评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,697评论 2 351

推荐阅读更多精彩内容

  • 1. 安装 git 不同系统下 git 的安装 Mac上可以在终端上输入: git --version 来查看gi...
    学生陈希阅读 1,646评论 0 4
  • Git问题Everything up-to-date解决e[http://cbsfly.github.io/git...
    似锦少年Jory阅读 200评论 0 0
  • 一、简介 1.概述 Git 是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。Git 是 Li...
    会思考的鸭子阅读 1,501评论 0 13
  • Git 在上家公司时使用git管理代码,当时使用的稀里糊涂,有些地方不是太明白。现在这家公司把代码移到git上管理...
    圆土豆阅读 600评论 0 50
  • Git和GitHub一直在用,但是没有详细学习过,只会几个简单的命令,做一些提交上传的操作。这几天公司没项目,比较...
    _赖笔小新阅读 8,317评论 2 110