这里记录一些 Git 在 Windows 操作系统下使用方法:

  安装完毕后,先让Git 记录自己的名字:

$ git config --global user.name "Your Name"
$ git config --global user.email "email@example.com"

一、 创建版本库

  在要创建版本库的文件夹空白处 右键打开菜单 选择 "Git Bash Here" 选项来打开 类似 "命令行"的窗口

  确定好目录后  就可以利用 git init 把目录变成仓库

  $ git init

Initialized empty Git repository in xxxxxxxxx

二、添加文件到仓库

  命令  $git add <file> 添加到仓库, 然后 $git commit 提交到仓库

$git add index.php

$git commit -m "添加修改注释"  //注释部分很重要 必须

三、查看状态

  $git status    //查看结果

  $git diff      //查看修改部分

四、版本回退

  $git log     //查看历史记录

  $git reset --hard HEAD~1  //会退到历史上上1个版本

  $git reset --hard xxxxxxid  //会退到ID为 xxxx 的版本

  $git reflog     //获取 Git 上操作记录

五、撤销修改

$git checkout -- file     //撤销修改  -- 前后都有空格 误删文件也可以回复

$git rm index.php     //删除文件的话 得运行一遍

   以上为本地部分的操作


  网络部分

六、远程仓库

$git remote add origin git@github.com:xiaoyueguang/JavaScript-Libraries.git  //将目前本地仓库 连接到 远程仓库上

$git push -u origin master  //推送 master 分支上所有的内容到远程仓库(第一次关联的时候使用)

$git push origin master  //推送 master 分支上最新的修改到远程仓库(本地修改提交后使用)

$git clone git@github.com:xiaoyueguang/JavaScript-Libraries.git  //将远程仓库 创建以该仓库名的文件夹,复制内容到本地上。

$git pull origin master  //拉取远程仓库上 master 分支的所有内容到本地仓库里

七、分支管理

  分支是GIT非常重要的概念。每个人都会有不同的分支。

  一般我都使用以下分支

    master 为 主分支,是最稳定的.只有当 dev 开发分支上功能稳定的时候,合并到 master 分支上,并发布一个新版本。需要时刻同步。

    dev 为 开发的分支,平时开发完成后将开发分支合并到该分支上。需要时刻同步。

    issue 为 BUG 分支。修复 BUG 时创建该分支,修复完成后合并到 出 BUG 的分支上,并删除该分支。不需要时刻同步。

    feature 为 开发新功能分支。完成后合并到 dev 分支上并删除。视情况而定(多人协作则时刻同步,另建分支合并上去。单人开发则无需时刻同步,直接合并到DEV分支上。)

    gh-pages 为 github 主页的分支(存放主页内容)。

    除此之外,每次开发新功能的时候应当创建一个新分支,完成后合并到 dev 分支上。

$git checkout -b dev  //创建并切换到 dev 分支进行开发(切换分支后,本地仓库内容都会有所变化),所以要 即时保存当前工作内容 或者 提交修改

$git branch  //查看所有分支,当前分支前会有 * 号

$git branch dev  //创建分支

$git merge dev  //合并 dev 分支到当前分支

$git branch -d dev  //删除分支

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

  冲突:

  有时候你开发的周期比较长,在你开发期间,团队里有人提交了 commit ,会导致远程仓库的内容和你当前本地内容不一致,这时候合并会出现冲突!

  当冲突出现的时候, GIT 会把内容放到一起, 在文件里 用 <<<<<<, >>>>>>, ====== 表示出不同分支的内容。

  等我们手动解决后,再利用  git add、 git commit 来完成提交。

  BUG:

  当出现一个急需处理的BUG后,我们应当这么做

$git stash  //保存当前的工作区(可保存多次)

$git status  //查看工作区

$git checkout master  //跳转到出 BUG 的分支

$git checkout -b issue-101  //创建 BUG 分支

//做完相应的修改后,提交

$git checkout master  //跳转到出 BUG 的分支

$git merge -m "合并分支" issue-101  //合并分支

$git branch -d issue-101  //删除 BUG 分支

$git stash list  //查看工作区

$git stash apply  //恢复工作区, stash内容还在

$git stash pop  //恢复工作区,stash内容清空(建议采用此方法)

八、标签管理

  给当前状态打个标签,以后可以方便的查看该标签的状态。

$git tag V1.0  //在当前的 commit 上 新建一个标签

$git tag -a V1.0 -m "标签状态"  //指定标签信息

$git tag -s V1.0 -m "PGP签名"

$git tag  //查看所有标签

$git push origin V1.0  //推送本地标签到远程仓库

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

$git tag -d V1.0  //删除标签

$git push origin :refs/tags/V1.0  //删除远程标签


九、自定义 GIT

  为了让 GIT 更容易使用,我们可以自定义 GIT。

$git config --global alias.co checkout  // co = checkout

$git config --global alias.br branch  // br = branch

$git config --global alias.ci commit  // ci = commit

Git 版本控制 在 WIN 下的一些使用方法的更多相关文章

  1. Git版本控制与工作流

    基本概念 Git是什么? Git是分布式版本控制系统,与SVN类似的集中化版本控制系统相比,集中化版本控制系统虽然能够令多个团队成员一起协作开发,但有时如果中央服务器宕机的话,谁也无法在宕机期间提交更 ...

  2. Git版本控制与工作流详解

    这篇文章是针对git版本控制和工作流的总结,如果有些朋友之前还没使用过git,对git的基本概念和命令不是很熟悉,可以从以下基本教程入手: 专为设计师而写的GitHub快速入门教程 git – 简明指 ...

  3. win下 git gui 使用教程

    现在很多都有git来托管项目或者来查找资料,但是看起来操作不是很方便,现在由于win下可以直接使用git gui,让使用git变得方便,当然这只是针对日常简单的使用,如果想详细的使用,可以去参考廖学峰 ...

  4. 版本控制工具——Git常用操作(下)

    本文由云+社区发表 作者:工程师小熊 摘要:上一集我们一起入门学习了git的基本概念和git常用的操作,包括提交和同步代码.使用分支.出现代码冲突的解决办法.紧急保存现场和恢复现场的操作.学会以后已经 ...

  5. WIN下Git GUI 教程

    现在很多都有git来托管项目或者来查找资料,但是看起来操作不是很方便,现在由于win下可以直接使用git gui,让使用git变得方便,当然这只是针对日常简单的使用,如果想详细的使用,可以去参考廖学峰 ...

  6. 【GitHub Desktop】MacOS和Win下配置及简单的使用

    一. GitHub介绍 1.GitHub 是为开发者提供 Git 仓库的托管服务.这是一个让开发者与朋友.同事.同学及陌生人共享代码的完美场所. 总结一下,GitHub 最大的特征是"面向人 ...

  7. Git版本控制使用介绍

    Git是什么? Git是一款免费.开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目. Git与SVN的最主要的区别? Git是分布式的,SVN不是 Git没有一个全局的版本号,而SVN有 ...

  8. Qt Creator 搭配Git 版本控制

    再次介绍一下Git的使用,这次是在Coding.net上部署项目的.这个是写给大作业合作的小伙伴们(我和我的A奶朋友们和某A的男朋友)看的. 安装Git 首先安装Git(msysGit) 下载地址 h ...

  9. Win下必备利器之Cmder

    诚言,对于开发码字者,Mac和Linux果断要比Windows更贴心;但只要折腾下,Windows下也是有不少利器的.之前就有在Windows下效率必备软件一文中对此做了下记载:其虽没oh-my-zs ...

随机推荐

  1. POJ 2155 2维线段树 || 2维BIT

    #include <iostream> #include <cstring> #include <cstdio> #include <algorithm> ...

  2. E - 滑雪

    Time Limit:1000MS     Memory Limit:65536KB     64bit IO Format:%I64d & %I64u Submit Status Pract ...

  3. eclipse生成doc文件乱码

    正确生成:在所写项目右击----Export----Java----javadoc---next ----一直next---finish. 乱码时:1)右击----Export----Java---- ...

  4. 在线聊天室的实现(1)--websocket协议和javascript版的api

    前言: 大家刚学socket编程的时候, 往往以聊天室作为学习DEMO, 实现简单且上手容易. 该Demo被不同语言实现和演绎, 网上相关资料亦不胜枚举. 以至于很多技术书籍在讲解网络相关的编程时, ...

  5. JSBinding+SharpKit / JavaScript调试

    注意: 1 Firefox 的版本用41 2 我发现调试很难用的,现在我都用打印 步骤参考图:

  6. 常见C内存管理程序

    本文主要关注的是C内存管理程序,比较著名的几个C内存管理程序,其中包括: l   Doug Lea Malloc:Doug Lea Malloc实际上是完整的一组分配程序,其中包括Doug Lea的原 ...

  7. linux shell:mysql bin_log定期清理脚本

    需求: 1.自动处理mysql bin日志脚本 2.输出可读log 3.保留1周的日志 4.对所有数据库统一处理.   实现过程描述:   思路:两种方式实现 1.mysql目录通过ls获取bin日志 ...

  8. mysql 启动 pid报错解决方法

    在安装好mysqld的时候 启动的时候报错如下: [root@ mysql]# service mysqld start Starting MySQL.The server quit without ...

  9. 基于adt-bundle-windows-x86的android开发环境搭建

    0,简介: 最近简单着手了解 android 开发.工欲善其事,必先利其器. 我本人不太喜欢使用java 开发,所以简单了解了下其 c# c++都可以进行android 开发,用c++的话要使用NDK ...

  10. python3爬虫 url管理器

    import urllib.request #python3中将urllib2拆分为了urllib.request.urllib.error.urllib.response等 import http. ...