全视图了解:看完下面内容,再回头看,会有不一样的风景!

1、明白git的四个区

  • Workspace(工作区):平时我们写代码的地方。
  • Index(暂存区):写完代码后让它变成的待提交的状态。
  • Repository(本地仓库):提交暂存区的代码到这里,记录进入代码本地管理。
  • Remote(远程仓库):将本地仓库的修改的代码提交到远程,可以供远程协作的人下载。

下图(网上扣出来的很错),可以清晰的表示各区间的联系:

2、 代码提交

  远程代码clone到本地之前的事都不说(什么安装git ,怎么clone),文件到本地后,进行修改后,以下几个步骤可以提交到远程库。如下

      git add .   将工作区修改过的代码全部提交到 暂存区
      git commit -m "first commit"   将暂存区的代码提交到 本地仓库
      git remote add origin    远程仓库地址
      git push -u origin master 将 本地的仓库 的代码提交到 远程仓库

      后面两个命令:前者适用于代码存在于远程仓库(Remote)的情况。后者适用于本地仓库(Repository)初次上传到远程仓库的情况。

  上面注要是讲直接 披着提交到 远程仓库里面(也就是远程仓库origin/master主分支上)

  以上命令细解:

   ·1、修改代码后,将代码提交到暂存区(Index)
    git add . :添加当前目录所有的文件都进入暂存区(记得后面有一个点,不写点,可以用‘-A’代替)。
    git add <dir>:添加指定目录所有的文件(目录路径)都进入暂存区。
    git add <file1>:添加指定文件(文件路径 )进入暂存区。

    2、提交到暂存区后,怎么看你修改过那些文件?

      git status  可查看所有被修改过的文件,还可以查出有冲突的文件,已提交到本地仓库的不会展示。

   3、怎么查看修改了那些文件的具体修改了什么?

      git diff  查看所以修改过的文件修改的内容

      git diff  <file>  查看这个文件修改的内容  。<file>指 要查看的文件的路径

  4、将暂存区文件提交到本地仓库

      git commit -m <message>:将暂存区的文件上传到本地仓库,<message>的位置填写本次提交修改的内容和一些注释。

  5、将本地仓库提交到远程仓库

    git push <remote><branch>:将本地仓库新记录提交到远程仓库,<remote>位置填写远程仓库名称(没有改的话,默认为"origin"),<branch>填写远程仓库需要提交的分支。

  总结: 一般的话提的代码不会直接提交到远程库的master主分支上,都会在本地建一个分支 提交到 远程分支上,再合入到主分支上(master),所以 步骤一般是这样的:

      git  clone 远程地址;

      cd  项目目录     这里就应该可以看到是在master主分支上;  

      git  checkout -b  <name> 建一个分支并切换到该分支上,<name>分支名

      git  add -A 或 git add .      修改代码后,将修改的内容提交到 暂存区

      git commit -m"写你修改内容相关的说明文"     将暂存区的内容提交到本地库

      git push origin <name>   将本地库的内容提交到远程库里  <name>是该分支名

   ·    走完了以上几步,大家基本上就学会提交代码了。

      当然有的人可以还会问,在一个分支个提交了代码到远程分支上,我再修改了内容怎么做了?

       很简单: 重复后三个步骤就行了,会全部提交到同一远程分支上,这个和你一次提交所有代码和把所有代码分几次提交是一个样的。
    
  

3、多人协作做一个项目。

   1、拉远程库到本地库中(如你本来克隆了一个库在本地,在这之后远程库中有人合入了代码进去,你可以pull远程代码到本地,使你的本地代码和远程的代码一样,当然这时要切换上master主支上)

    git pull <remote><branch>:从远程仓库拉取代码到本地仓库,<remote>位置填写远程仓库名称,<branch>填写拉取远程仓库的分支。

    git pull  将所以远程分支拉入本地仓库

    说明: 这个用到pull是因为要用到远程相关的代码,不要在已经修改的分支上pull,要切换上master分支上再pull,你要做新的改动,可以再建一个分支,不要在以前的分支上再做了,因为那上面没有pull 的代码

  

    

  2、分支的功能:从同一份稳定代码拉出有相同代码的分支,每个人在自己的分支上开发提交代码,不会互相打扰,完成后再进行代码的合并。  

      git branch:列出所有本地分支
      git branch -r:列出所有远程分支
      git branch -a:列出所有本地分支和远程分支

      git branch <branch-name>:新建一个分支,但依然停留在当前分支,<branch-name>为新建的分支名
      git checkout -b <branch-name>:新建一个分支,并切换到该分支,<branch-name>为新建的分支名
      git checkout <branch-name>:切换到指定分支,并更新工作区,<branch-name>为指定的分支名
      git branch -d <branch-name>:删除分支,<branch-name>为指定的分支名
      git push origin --delete <branch-name>:删除远程分支,<branch-name>为指定的分支名
      git push origin <branch-name>:将当前分支上传到远程仓库,<branch-name>为新建的远程分支名
 
    分支命令很多  基本常用的就2,3个 ,git checkout -b <branch-name> 这是最常用的   还一个查看分支 git branch 
 
   3、合并分支
      git merge <branch-name>:合并指定分支到当前分支,<branch-name>是指定分支,将该分支代码合并到当前分支。
 
      这个一般不会用,常用了查看冲突上,
      如发现和master分支有冲突,怎么解决冲突?
      现在本分支上切换到 master 分支, git pull 一下,现切换上刚修改的分支上,git merge master  合并完成后,分支会变成 xxxx|MERGING(”xxxx“指分支名) 状态,再用 git status 查看一下是那个文件冲  突。再找到相应文件,修改冲突的地方,再提交一次(进行代码提交换的后三步骤),xxxx|MERGING 状态就会变以分支名了(恢复到正常状态)。
 
最后附一张 常用的Git命令表非常实用
 

git 的日常使用命令的更多相关文章

  1. 从零开始使用git第二篇:git的日常操作

    从零开始使用git 第二篇:git的日常操作 第一篇:从零开始使用git第一篇:下载安装配置 第二篇:从零开始使用git第二篇:git实践操作 第三篇:从零开始使用git第三篇:git撤销操作.分支操 ...

  2. 关于git你日常工作中会用到的一些东西

    前言 git是一个版本控制工具, 版本控制主要的好处有三点: 从当前版本回退到任意版本 查看历史版本 对比两个版本差异 git 相关术语 repository 仓库 branch 分支 summary ...

  3. 2.goldengate日常维护命令(转载)

    goldengate日常维护命令 发表于 2013 年 7 月 4 日 由 Asysdba 1.查看进程状态 GGSCI (PONY) 2> info all 2.查看进程详细状态,有助于排错 ...

  4. svn服务配置和日常维护命令

    Subversion独立服务和与apache整合服务. 一 .Svn独立服务安装 操作系统: Redhat Linux AS3  AS 4   ContOS AS 4 安装包获取: 下载[url]ht ...

  5. 程序员必备:Oracle日常维护命令

        上一篇讲了Linux的日常维护命令,这篇讲讲Oracle的日常维护命令.工作中需要使用Oracle数据库的童鞋们,相信或多或少都需要对Oracle做一些基本的维护操作,例如导入导出总该有吧?( ...

  6. git plumbing 更加底层命令解析-深入理解GIT

    原文: http://rypress.com/tutorials/git/plumbing 本文详细介绍GIT Plumbing--更加底层的git命令,你将会对git在内部是如何管理和呈现一个项目r ...

  7. mha日常维护命令

    mha日常维护命令 http://m.blog.chinaunix.net/uid-28437434-id-3959021.html?/13033.shtml 1.查看ssh登陆是否成功masterh ...

  8. Git中的merge命令实现中出现问题及其解决

    Git中的merge命令实现和工作方式 2015年8月17日星期一 丹丹 git代码在合并两个分支的时候总是会出现一下的错误提示,不能正常的完成合并分支,错误提示如图所示: 但是在其他的终端是可以完成 ...

  9. github总结(4)--关于git reset --hard这个命令的惨痛教训

    背景叙述: 前几天,上传自己的个站到git上的时候,手欠脑发晕的用了次git reset --hard xxxxxx 命令.由于只在线上传入了一个index.html页面(自己都不知道自己咋想的,就这 ...

随机推荐

  1. windows server 2008 r2 IIS 6 元数据库与IIS 6 配置的兼容性 解决方案

    1 菜单-管理工具-服务器管理 2 添加角色服务 3 选中 IIS6 管理兼容性 4 安装完成 5 在IIS上新建一个相应端口的网站 6重新加载项目,OK

  2. Laravel 5.3 使用内置的 Auth 组件实现多用户认证功能

    https://blog.csdn.net/kevinbai_cn/article/details/54341779 概述 在开发中,我们经常会遇到多种类型的用户的认证问题,比如后台的管理员和前台的普 ...

  3. PHP 基础篇 - PHP 中 DES 加解密详解

    一.简介 DES 是对称性加密里面常见一种,全称为 Data Encryption Standard,即数据加密标准,是一种使用密钥加密的块算法.密钥长度是64位(bit),超过位数密钥被忽略.所谓对 ...

  4. sdut3140 A*B(math)

    题目:传送门 题目描述 Your task is to find the minimal positive integer number Q so that the product of digits ...

  5. Linux文件权限分析

    一.用户组概念  在linux系统中,每个用户必属于一个组,不能独立于组之外.每个文件都有所有者,所在组和其他组这三个概念. (1)所有者:一般为文件的创建者,谁创建了该文件,就成为了该文件的所有者, ...

  6. 转:js获取json中key所对应的value值

    <script type="text/javascript"> getJson('age'); function getJson(key){ var jsonObj={ ...

  7. PKU 2506 Tiling(递推+高精度||string应用)

    题目大意:原题链接有2×1和2×2两种规格的地板,现要拼2×n的形状,共有多少种情况,首先要做这道题目要先对递推有一定的了解.解题思路:1.假设我们已经铺好了2×(n-1)的情形,则要铺到2×n则只能 ...

  8. css伪类与伪元素

    原文:http://www.alloyteam.com/2016/05/summary-of-pseudo-classes-and-pseudo-elements/ 伪类的操作对象是文档树中已有的元素 ...

  9. [acm/icpc2016ChinaFinal][CodeforcesGym101194] Mr. Panda and Fantastic Beasts

    地址:http://codeforces.com/gym/101194 题目:略 思路: 这题做法挺多的,可以sam也可以后缀数组,我用sam做的. 1.我自己yy的思路(瞎bb的) 把第一个串建立s ...

  10. ACM对拍程序

    1.把所需对拍的代码的可执行文件a.exe b.exe放在同一目录下 2.把rand数据的代码的可执行文件c.exe放在该目录下 3.新建一个txt文件,里面添加代码,后把格式改成bat @echo ...