Git的一些基本概念

  • 设置自己的用户名和邮箱
    git config –global user.name "Your Name"git config –global user.email "you@example.com"
  • 修改到提交之间有一个缓存区
    • 提交到缓存区
      git add .
      当前所有修改提交到缓存区,也可以单独指定
    • git diff --cached
      查看缓存区和本地仓库里的差异
    • git diff HEAD
      查看已缓存和当前的区别
    • git diff
      查看当前未缓存的和本地仓库里的区别
    • git diff --stat
      显示摘要
  • 撤销缓存区里的一个更改,例如hello.rb
    git reset HEAD -- hello.rb
  • git rm file
    将file从文件缓存区、本地目录中移除
  • git rm file --cached
    只从缓存区移除,保存本地目录中的


分支操作

  • git branch
    列出可用的分支
  • git branch jser.me
    创建jser.me分支
  • git checkout -b jser.me
    检查jser.me分支是否存在,不存在就创建,并且切换过去
  • git branch -d jser.me
    删除分支jser.me
  • git merge
    其它分支合并到当前分支
  • git checkout -b gh-pages origin/gh-pages
    检出并且设置当前分支为远程分支gh-pages


Log查看

  • git log --oneline
    紧凑查看
  • git log --graph
    图形显示
  • git log erlang ^master
    查看只在erlang分支里的修改
  • git log --grep
    正则取一个log
  • git shortlog master
    生成一个简报


里程碑

  • git tag -a v1.0
    打上v1.0


恢复删除的文件

  • git checkout commitid -- pathfile


与人分享

  • git remote
    列出远端的别名
  • git remote add remotename remotepath
    以remotename命名remotepath
  • git remote rm remotename
    删除别名为remotename的远程仓库
  • git fetch
    只下载
  • git pull
    下载并更新
  • git push remotename branch
    推送本地分支branch到远程仓库remotename的branch分支

一些原则新功能尽可能的开分支,但是定期合到master上来,不要把某一个分支长

时间的开发 使用git-flow

Git的几个关键知识点

  • 有三种状态:

    • 暂存 staged
    • 修改 modify
    • 已经提交
  • git status
    • 前面状态有两列,头一列是暂存区的改动情况,如果你commit,它会提交,第二列是当前共工作区的状态,它是不会被提交的

冲突之后的解决找到冲突的地方,手工解决,然后git add filename; git commite

只合并特定的分支特定文件

  • 使用命令
    git cherry-pick #commitid
  • checkout方法
    git checkout branch -- filename


查看和远程分支的对比

  • 先把远程分支搞到本地
    git fetch origin master:temp, 从远程的origin仓库的master分支下载到本地并新建一个分支temp
  • 比较分支
    git diff temp
  • 合并特定的文件,参考上面的
  • 删除无用的分支
    git branch -d temp


git diff

  • 只显示有对比的文件
    git diff 608e120 4abe32e --name-only
  • 配合搞成压缩文件
    git diff 608e120 4abe32e --name-only | xargs zip update.zip
  • 如果不是查看每个文件的详细差别,而是统计一下有哪些文件被改动,有多少行被改 动,就可以使用‘--stat' 参数。
  • diff指定的文件


查看今天的更改

  • git log --since=1.days
 
 

Git的一些基本概念的更多相关文章

  1. GIT入门篇-基本概念与操作

    GIT 首先必须说明的是, 这篇文章不是阐述GIT原理性和比较深入的文章.只是对于日常开发中比较常用的需求的总结和GIT这些命令大体的原理解释.所以掌握这个只能说能够应付一定的开发需求.但是如果你是个 ...

  2. GIT入门笔记(3)- git中的一些概念和原理

    一.git管理过程中所处的4个阶段: 工作目录(workspace) 暂存区(index) 本地仓库(local repository) 远程仓库(remote repository) 二.工作目录+ ...

  3. git学习记录——基础概念和文件的基本操作

    夸一下git git是当前世界上最先进的分布式版本控制系统 优势: 1.不必联网 2.Git极其强大的分支管理,把SVN等远远抛在了后面. 集中式的代表CVS和SVN 分布式的代表BitKeeper, ...

  4. svn老鸟转用git必须理解的概念

    不都是SCM代码管理嘛,有很大区别么?很多svn老鸟都是抱着这样的心态去学习git,然后无一幸免地陷入“查阅过很多资料,依然掌握不好”的困境,至少我们团队是这样的. 网上的资料确实已经很多了,却没有把 ...

  5. Android中 Git 使用中几个概念

    1.仓库(版本库) 版本库又名仓库,英文名repository,你可以简单理解成一个目录,这个目录里面的所有文件都可以被Git管理起来,每个文件的修改.删除,Git都能跟踪,以便任何时刻都可以追踪历史 ...

  6. svn git 必须理解的概念

    不都是SCM代码管理嘛,有很大区别么?很多svn老鸟都是抱着这样的心态去学习git,然后无一幸免地陷入“查阅过很多资料,依然掌握不好”的困境,至少我们团队是这样的. 网上的资料确实已经很多了,却没有把 ...

  7. git 学习之基本概念

    在学习 Git 的时候我们经常会听到工作区,版本库,暂存区.那么这些东西指的是什么呢?本次我们就一起学习一下. 工作区 顾名思义:工作的区域,那么你一般在哪工作呢?当然是你本地可以看到的目录啦! 版本 ...

  8. [TFS4]TFS git地址,分支概念

    1)上传本地代码到TFS a.Generate Git Credentials,即创建git账户密码 b)上传本地代码 git add *git commit -m "纳入管理" ...

  9. [git] 细说commit (git add/commit/diff/rm/reset 以及 index 的概念)

    http://kasicass.blog.163.com/blog/static/39561920133294219374/ 创建测试仓库 $ git init $ echo "line o ...

随机推荐

  1. handlebar helper帮助方法

    handlebars相对来讲算一个轻量级.高性能的模板引擎,因其简单.直观.不污染HTML的特性.另一方面,handlebars作为一个logicless的模板,不支持特别复杂的表达式.语句,只内置了 ...

  2. WPF_X命名空间

    x名称空间映射的是http://schemas.microsoft.com/winfx/2006/xaml,也称为"XAML名称空间"

  3. [记录]calculate age based on date of birth

    calculate age based on date of birth know one new webiste:eval.in run php code

  4. js动态生成按钮,页面用DIV简单布局2

    对前边不完善的修改 <!DOCTYPE html><html><head><title>test.html</title> <meta ...

  5. dede常用命令

    获取日期:全局:{dede:field.pubdate function="MyDate('Y-m-d H:i',@me)"/}   局部:[field:pubdate funct ...

  6. 20160512--hibernate--缓存

    缓存 缓存的作用主要用来提高性能,可以简单的理解成一个Map:使用缓存涉及到三个操作:把数据放入缓存.从缓存中获取数据.删除缓存中的无效数据.   原理模拟分析:(不能运行,只是模拟)(缓存实现复杂, ...

  7. Opencv——将摄像头拍摄写成视频文件

    这里主要利用了Opencv打开摄像头的代码,以及写入视频的函数,只是这里要注意的是摄像头好像没有帧率,在cvCreateVideoWriter,时要自己设置 #include"cv.h&qu ...

  8. Google Map JavaScript API V3 实例大全

    Google Map JavaScript API V3 实例大全 基础知识 简单的例子 地理位置 语言 位置 坐标 简单的投影 事件 简单事件 关闭事件 多次添加事件 事件属性 控制 php禁用ui ...

  9. Sencha Touch id 和 itemId

    通过id获得组件: var view=Ext.getCmp('id'); 通过itemId获得组件: var view = ComponentQuery.query('view_xtype'), // ...

  10. java集合 collection-list-LinkedList

    import java.util.*; /* LinkedList:特有方法: addFirst(); addLast(); getFirst(); getLast(); 获取元素,但不删除元素.如果 ...