几个重要的概念 

 首先先明确几个概念:

WorkPlace : 工作区

  Index: 暂存区

  Repository: 本地仓库/版本库

  Remote: 远程仓库

  当在Remote(如Github)上面clone一个项目到本地时(假设项目名为GitTest),在本地就会看到一个名为GitTest的目录,目录下有项目代码和一个名为.git的目录,什么是工作区呢,就是除了.git文件夹以外的所有东西,我们主要在工作区上阅读,修改,添加删除代码和其他内容,而这个.git目录就称为一个版本库,这个版本库中存放有很多东西,比如有Git为我们自动创建的一个master分支一个指向该分支的一个Head指针,其中就有一个名称为index的区域,就是暂存区,下面盗个图:

Git命令详解

  git init  将当前目录初始化为一个git可以管理的仓库

  git clone [url]  从指定的url下载一个项目到当前目录,自动将其变为一个git仓库

  git config [--global] user.name "zhangSan"  git config [--global] user.email "zhangsan@qq.com"

   顾名思义设置一个用户名和邮箱,主要用于在提交代码时显示,方便别人知道这个代码是谁提交的,但只在当前仓库中起作用,如果加上----global参数 则会在所有仓库都显示这个用户名和邮箱.

  

  git add 文件 :添加指定文件到暂存区

  git add -A: 添加当前工作区所有修改文件到暂存区

  git commit -m "...." :将暂存区的内容提交到本地仓库,省略号中的内容最好是有意义的注释,方便自己和别人以后查看.

  git status   查看当前仓库的状态,能够清晰地看到哪些文件修改了,哪些文件在暂存区等信息

  git diff 文件名 :如果文件修改了,已经添加到暂存区,我们希望看一下文件具体哪些内容被修改了,可以使用此命令,能够看到具体修改了的内容

  git log 查看项目的提交日志,包含一个版本号,提交者的名称和邮箱,提交日期,以及提交时添加的注释.

  git reset --hard HEAD^ :回退到上一个版本,如果使用两个^就是回退到上上个版本

   git reset --hard 76786554  :根据版本号回退到指定版本,版本号可以通过git log 查看,版本号很长,取前几位即可

   git checkout --a.txt    :撤销对a.txt的修改,这里分两种情况,1 如果a.txt已修改,但未提交到暂存区,则会将a.txt撤销到和版本库相同的状态. 2 如果a.txt已经添加到暂存区又做了修改,则会将a.txt撤销到刚添加到暂存区时候的状态.

  git reset HEAD a.txt   :如果a.txt已经修改并添加到暂存区,但我们希望将它撤回到工作区,使用此命令

  git rm a.txt   :从版本库中删除a.txt

  git pull <远程主机名> <远程分支名>:<本地分支名>:   取回远程主机某个分支的更新,再与本地的指定分支合并

  git pull origin develop:master: 取回远程主机的develop分支与本地的master分支合并

  git push <远程主机名> <本地分支名>:<远程分支名>: 将本地指定分支的更新,推送到远程主机的指定分支

   git push origin master  :将本地库的master分支项目push到远程库中

  git branch   :查看当前分支

  git branch -r:查看远程分支

  git branch -a: 查看所有分支

  git branch develop:从当前分之中创建一条名为develop的分支

  git checkout develop:从当前分支跳转到名为develop的分支上去

  git checkout -b develop :从当前分支创建一条名为develop的分支并且跳转到该分支上去,相当于上面两条命令的简化

  git merge develop:将名为develop的分支合并到当前分支上来

  git branch -d develop: 将名为develop的分支删除

  git 的命令还有很多,比较常用的就是这些,以后碰到了再随时补充吧~

Git初探--笔记整理和Git命令详解的更多相关文章

  1. [ kvm ] 学习笔记 5:QEMU-KVM 命令详解

    1. QEMU.KVM .QEMU-KVM QEMU 提供了一系列的硬件模拟设备(cpu.网卡.磁盘等),客户机指令都需要QEMU翻译,因此性能较差.KVM 是Linux 内核提供的虚拟化模块,负责C ...

  2. Linux笔记之——Linux关机命令详解(转)

    原文连接:http://www.jb51.net/os/RedHat/1334.html 在linux下一些常用的关机/重启命令有shutdown.halt.reboot.及init,它们都可以达到重 ...

  3. linux命令学习笔记-kill和killall命令详解

    *杀死进程最安全的方法是单纯使用kill命令,不加修饰符,不带标志. 首先使用ps -ef命令确定要杀死进程的PID,然后输入以下命令: # kill -pid 注释:标准的kill命令通常都能达到目 ...

  4. Git命令详解

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

  5. Git 常用命令详解

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

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

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

  7. 【转】 Git 常用命令详解(二)----不错

    原文网址:http://blog.csdn.net/ithomer/article/details/7529022 Git 是一个很强大的分布式版本管理工具,它不但适用于管理大型开源软件的源代码(如: ...

  8. git命令详解( 七 )

    此为git命令详解的第七篇 这章我们可以来逐渐揭开 git push.fetch 和 pull 的神秘面纱了.我们会逐个介绍这几个命令,它们在理念上是非常相似的.   git push的参数 git ...

  9. git命令详解( 四 )

    此篇为git命令详解的第四篇,话不多说,我们直接上知识点好吧 git Push 偏离的工作 gitPush: 此命令负责将你的变更上传到指定的远程仓库,并在远程仓库上合并你的新提交记录.一旦 git ...

随机推荐

  1. JavaWeb——Filter

    一.基本概念 之前我们用一篇博文介绍了Servlet相关的知识,有了那篇博文的知识积淀,今天我们学习Filter将会非常轻松,因为Filter有很多地方和Servlet类似,下面在讲Filter的时候 ...

  2. 通往全栈工程师的捷径 —— react

    腾讯Bugly特约作者: 左明 首先,我们来看看 React 在世界范围的热度趋势,下图是关键词“房价”和 “React” 在 Google Trends 上的搜索量对比,蓝色的是 React,红色的 ...

  3. 【大型网站技术实践】初级篇:借助LVS+Keepalived实现负载均衡

    一.负载均衡:必不可少的基础手段 1.1 找更多的牛来拉车吧 当前大多数的互联网系统都使用了服务器集群技术,集群即将相同服务部署在多台服务器上构成一个集群整体对外提供服务,这些集群可以是Web应用服务 ...

  4. Nhibernate的Session管理

    参考:http://www.cnblogs.com/renrenqq/archive/2006/08/04/467688.html 但这个方法还不能解决Session缓存问题,由于创建Session需 ...

  5. ASP.NET加密和解密数据库连接字符串

    大家知道,在应用程序中进行数据库操作需要连接字符串,而如果没有连接字符串,我们就无法在应用程序中完成检索数据,创建数据等一系列的数据库操作.当有人想要获取你程序中的数据库信息,他首先看到的可能会是We ...

  6. 界面设计技法之css布局

    css布局之于页面就如同ECMAScript之于JS一般,细想一番,html就如同语文,css就如同数学,js呢,就是物理,有些扯远,这里就先不展开了. 回到主题,从最开始的css到如今的sass(l ...

  7. Struts2实现ajax的两种方式

    基于Struts2框架下实现Ajax有两种方式,第一种是原声的方式,另外一种是struts2自带的一个插件. js部分调用方式是一样的: JS代码: function testAjax() { var ...

  8. Java获取本机的IP与MAC地址

    有些机器有许多虚拟的网卡,获取IP地址时会出现一些意外,所以需要一些验证: // 获取mac地址 public static String getMacAddress() { try { Enumer ...

  9. kvm 使用入门详解

    kvm 是虚拟化技术的一个典型实现,功能非常强大,使用很方便.kvm 本身主要实现对 CPU 的虚拟化,内存和IO的虚拟化使用了开源软件 qemu,qemu 是纯软件层面的虚拟化,其实就是个模拟器.k ...

  10. C 盘的不速之客

      C 盘的报告内容既然上GB的空间 操作系统版本 原来是微软这个查找解决异常关闭解决方案生成的报告   参考 How To Disable Vista Error Reporting Feature ...