$ git init               当前目录建立GIT可以管理的仓库(版本库),生成一个.git的隐藏文件夹

$ git add <filename>        将工作区的文件修改添加到版本库的暂存区

$ git commit -m "tips"          将暂存区的所有修改添加到分支上,tips是本次提交的备注,方便查看

$ git status             本地工作区与分支的代码比较,工作区文件与版本库比较的状态

(modified 文件被修改 ; deleted 工作区文件被删除 ; Untracked 文件未跟踪,版本库没有 ; new file 文件add到暂存区,还未添加到分支  )

$ git diff <filename>          比较工作区和版本库的文件,文件内容具体哪些不同

$ git log              版本库状态信息,git commit的记录信息,便于跟踪提交每次都有哪些修改

$ git reset --hard <版本号>       版本库回退到某个版本的状态

$ git reset --hard HEAD^       回退到当前版本的上一个版本,撤销上次的提交,HEAD指向当前版本的指针

$ git reflog             记录你的每一次git命令,便于跟踪

$ git checkout --<filename>      工作区的文件回退到最近一次add或commit时的状态,删除掉的文件也可还原回来

$ git reset HEAD <filename>     撤销暂存区的文件的修改,然后再checkout撤销工作区的修改

$ git rm <filename>         将删除消息提交到暂存区,commit后版本库的文件会被删除

$ git checkout -b <name>      创建新的分支name,-b会将当前工作分支切换到dev,相当于下面两条命令

$ git branch <name>         创建新的分支name

$ git checkout <name>        切换当前工作分支为name

$ git branch             查看所有分支,前面带*号,表明是当前所在分支

$ git merge <name>          合并name分支到当前分支

$ git branch -d <name>        删除分支name

$ git log --graph           查看分支合并图

$ git stash             保存当前分支工作现场

$ git stash pop           恢复保存的工作现场 

$ git branch -D <name>       强行删除分支(丢弃分支的所有提交) 

$ git remote -v           查看远程库信息

$ git pull              抓取远程的新的提交(推送前最好先pull一下,免得覆盖别人的代码)

$ git push origin branch-name    从本地推送分支  

$ git checkout -b branch-name origin/branch-name在本地创建远程分支对应的分支

$ git brach --set-upstream branch-name origin/branch-name建立本地分支和远程分支关联

$ git tag <name>          在当前分支打一个标签

$ git tag              查看所有标签

$ git tag -a <tagname> -m "balabala"    指定标签信息

$ git tag -s <tagname> -m "balabala"     用PGP签名标签

$ git tag -d <tagname>        删除一个本地的标签

$ git push origin <tagname>     推送一个本地标签到远程分支

$ git push origin --tags        推送全部未推送过的本地标签

$ git push origin : refs/tags/<tagname>删除一个远程标签

<<<<<<<<<<<<<<<<<OVER>>>>>>>>>>>>>>>>>>>>>>>>>        

  HEAD指针严格来说不是指向提交的,而是指向master主分支的,每一次提交主分支就多一个节点,master指向最新提交,HEAD指向master,就能确定当前分支为主分支和当前分支的最新提交节点。

  当我们创建分支dev时,GIT创建一个dev的指针,指向master相同的提交,再把HEAD指向dev,表示当前工作节点在dev分支上。当我们在dev分支提交时,dev指向新的提交(红色节点),master指针不变,这样就确保了两个分支能同时存在,HEAD指向工作区当前在哪个分支上工作。

  当我们要合并两个分支时,就需要将两个分支的提交内容合并,当主分支没有新的提交时,只需要将master分支指向dev指向的提交节点,即可完成合并,但当两个分支都有各自不同的提交时,GIT小心的合并各自提交的修改,遇到冲突(即两个分支提交都对同一个文件修改)时,需要人工去解决冲突(人工合并文件)。

GIT使用教程——命令详解的更多相关文章

  1. Windows系统Git安装教程(详解Git安装过程)

    Windows系统Git安装教程(详解Git安装过程)   今天更换电脑系统,需要重新安装Git,正好做个记录,希望对第一次使用的博友能有所帮助! 获取Git安装程序   到Git官网下载,网站地址: ...

  2. Git入门教程,详解Git文件的四大状态

    大家好,欢迎来到周一git专题. git clone 在上一篇文章当中我们聊了怎么在github当中创建一个属于自己的项目(repository),简称repo.除了建立自己的repo之外,我们更多的 ...

  3. git push&pull命令详解

    git pull的作用是从一个仓库或者本地的分支拉取并且整合代码. git pull [<options>] [<repository> [<refspec>-​] ...

  4. Git的使用以及常用命令(详解)

    一. 版本控制工具 什么是版本控制系统? 版本控制系统(Version Control System):是一种记录一个或若干文件内容变化,以便将来查阅特定版 本修订情况的系统.版本控制系统不仅可以应用 ...

  5. Git初探--笔记整理和Git命令详解

    几个重要的概念 首先先明确几个概念: WorkPlace : 工作区 Index: 暂存区 Repository: 本地仓库/版本库 Remote: 远程仓库 当在Remote(如Github)上面c ...

  6. Git 常用命令详解

    Git 是一个很强大的分布式版本管理工具,它不但适用于管理大型开源软件的源代码(如:linux kernel),管理私人的文档和源代码也有很多优势(如:wsi-lgame-pro) Git 的更多介绍 ...

  7. Android Studio系列教程五--Gradle命令详解与导入第三方包

    Android Studio系列教程五--Gradle命令详解与导入第三方包 2015 年 01 月 05 日 DevTools 本文为个人原创,欢迎转载,但请务必在明显位置注明出处!http://s ...

  8. Git 常用命令详解(二)

    Git 是一个很强大的分布式版本管理工具,它不但适用于管理大型开源软件的源代码(如:linux kernel),管理私人的文档和源代码也有很多优势(如:wsi-lgame-pro) Git 的更多介绍 ...

  9. Git命令详解

    一个中文git手册:http://progit.org/book/zh/ 原文:http://blog.csdn.net/sunboy_2050/article/details/7529841 前面两 ...

随机推荐

  1. 01hive基础操作

    一. Hive基础概念 我自己本人一开始学习Hive的时候,最大的疑问就是hive和hbase到底有什么区别?(因为自己本身学校课程设置问题有了解到一丢丢hbase的知识) 所以先甩一篇博客提供给跟我 ...

  2. acm数论之旅--组合数(转载)

    随笔 - 20  文章 - 0  评论 - 73 ACM数论之旅8---组合数(组合大法好(,,• ₃ •,,) )  补充:全错排公式:https://blog.csdn.net/Carey_Lu/ ...

  3. 如何让后加载的元素被一开始就有的css样式渲染成功(强制提升css优先级)

    今天在做搜索框中的提示语下拉的时候,提示框把搜索框的底部的border遮住,导致看起来不是很美观: 因为下方的提示框是用js后加载的它的样式也是随着js一起加载的,而这个js和它的css我们是不能改动 ...

  4. [采坑记录] OneDrive同步失败 不能自动上传 不能同步 不能登陆

    虽然OneDrive送的空间并不大 但是用来传文档什么的还是够了 但是国内各种不舒服 比如说登陆不上(其他的微软系应用解决方法同理) 原因是因为DNS污染的问题 默认电脑链接上网络之后 DNS是路由器 ...

  5. BFS和DFS详解以及java实现(转载)

    作者:Leo-Yang 原文都先发布在作者个人博客:http://www.leoyang.net/ 本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连 ...

  6. Codeforces Round #597 (Div. 2)D(最小生成树)

    /*每个点自己建立一座发电站相当于向超级源点连一条长度为c[i]的边,连电线即为(k[i]+k[j])*两点间曼哈顿距离,跑最小生成树(prim适用于稠密图,kruscal适用于稀疏图)*/ #def ...

  7. 【译】高级T-SQL进阶系列 (三)【中篇】:理解公共表表达式(CTEs)

    [译注:此文为翻译,由于本人水平所限,疏漏在所难免,欢迎探讨指正] 原文链接:传送门. 一个简单的CTE例子 如前所述,CTE‘s提供给你了一个方法来更容易的书写复杂的代码以提高其可读性.假设你有列表 ...

  8. Spring boot security权限管理集成cas单点登录

    挣扎了两周,Spring security的cas终于搞出来了,废话不多说,开篇! Spring boot集成Spring security本篇是使用spring security集成cas,因此,先 ...

  9. Vue-状态管理Vuex的使用

    vuex是状态管理,是为了解决跨组件之间数据共享问题的,一个组件的数据变化会映射到使用这个数据的其他组件当中.如果刷新页面,之前存储的vuex数据全部都会被初始化掉.以一个全局单例模式管理当应用遇到多 ...

  10. ICCV2019 oral:Wavelet Domain Style Transfer for an Effective Perception-distortion Tradeoff in Single Image Super-Resolution

    引言 基于低分辨率的图像恢复高分辨图像具有重要意义,近年来,利用深度学习做单张图像超分辨主要有两个大方向:1.减小失真度(distortion, 意味着高PSNR)的图像超分辨,这类方法主要最小化均方 ...