作为一个一直用SVN的家伙,深深地感到了自己在版本控制工具上的落伍。。。。


首先必须强调的是: Git与Github不是一回事。 Git是目前世界上最先进的分布式版本控制系统,于2005年被linux创始人Linus开发出来。而Github是一个基于Git为全球开源项目免费提供git存储的网站,众多著名开源项目都迁移至Github~ 而开源时代的来临也使得软件行业活力倍增。

作为分布式版本控制系统的Git,与传统的CVS、SVN相比优势明显。传统的集中式系统,版本库集中存放在中央服务器,各个终端必须连接至中央服务器进行操作,这导致了许多的不方便。在Git中,没有中央服务器,每个终端上都有一个完整的版本库,安全性大大提升。(在集中式系统中,一旦中央服务器挂掉还是很棘手的) 不过在使用的时候,Git中也会有台主机担任相当于“中央服务器”的角色,它用来作为主分支方便所有人交换分支并进行总体的版本控制,但它并不是必须的。 Git相对于传统集中式版本控制系统的优势还不仅仅在于安全性,其暂存区、分支等概念也带来了很多的优势。

对于Git的使用,主要有客户端与命令行两种方式,个人觉得不一定必须去追求命令行的使用,非Linux环境下已经有了很好有的图形化界面干嘛不用?~   
    Github客户端:https://desktop.github.com/
    Sourcetree:https://www.sourcetreeapp.com/
    很多IDE中也已经集成了Git,比如Visual Studio、Storm系列,Sublime中也有Git插件。  关于客户端的使用就自行摸索了~
在命令行中使用,Linux自然不用说,而在Windows下主要是使用GitBash工具。本文中的演示也是基于Windows下的Git Bash

进入正题:
  
一、创建版本库并提交文件: 
        1、创建项目目录并使用git init命令将其变成一个Git可以管理的仓库:
        如:
               
        随后就会在该文件夹下发现隐藏属性的.git目录,Git就是使用这个目录来跟踪管理版本库的。

        2、创建文件并添加到仓库
              我已经在Data-Structure-in-JavaScript文件夹下创建了BinaryTree.js 将其添加到版本库的步骤如下:
              
             共需两步: 1、git add 文件名   对需要提交的文件进行add操作,可多次进行
                         
       2、git commit [-m 提交说明]  对之前add的文件执行提交,说明不是必须选项但强烈建议养成每次提交写说明的习惯。
             让我们把其它文件也加入:
             

            为什么要分两步操作呢?在Git中有着工作区与暂存区的概念,我们的项目目录即是工作区。而在版本库中,则有暂存区与分支。add操作是将当前修改提交到暂存区,而commit操作则是将暂存区所有的修改提交至分支。
二、与版本库进行交互
        1、查看当前状态:git status
            
            此时我们修改一下BinarTree.js,则会显示出修改过的文件 使用git diff命令还能显示修改过的位置
            
            修改过之后再次使用git add与git commit命令提交修改即可
        2、版本回退
            首先可以使用git log命令查看历史记录。使用该命令会显示从最近到最远的提交记录,每条记录中显示版本号、提交者、提交日期以及提交记录四项。
            
            使用git reset --hard commit_id命令进行回退
            
            只要本次进程没有关闭,还是可以通过同样的命令回到未来的版本。假如进程关闭之后再想回到未来版本的话,可以使用git reflog命令查看命令历史,从中获知未来版本的版本号并进行穿梭。重启Git Bash 操作如下
            
        3、撤销修改
            可以使用git checkout -- file命令撤销工作区的修改。很容易理解,检出操作会用最近一次commit或add的文件来覆盖当前修改过的文件,当前工作区的修改就等同于被撤销。这里如果已经添加到了暂存区,则会恢复暂存区的状态;如果还没添加至暂存区,则会回到版本库中的最新版本时的状态。
            如果修改已经添加至暂存区,则可以使用git reset HEAD file操作,将暂存区的修改撤销,重新放回工作区。此时,便可以使用checkout命令撤销工作区的修改~
            如果修改已经提交至版本库。。。 回退版本吧~
        4、删除文件
            删除文件的时候,我们直接在系统中删除文件。此时,git中便会显示删除的文件,此时可以使用 git rm 文件名 并提交将文件从版本库中删除;或者使用git checkout 文件名命令恢复文件。比如这里新建了remove.js文件,之后在系统中删除该文件。
            

总结:

命令 功能
git init 创建版本库
git add 文件名 将修改添加至暂存区
git commit 将暂存区的所有修改提交至版本库
git status 查看当前状态
git log 查看版本记录
git reflog 查看命令历史
git checkout -- 文件名 检出文件以撤销工作区修改
git reset HEAD file 撤销暂存区修改,恢复至工作区
git rm 文件名 删除文件

Git入门——本地版本库操作的更多相关文章

  1. git入门 创建版本库, 版本管理 分支 标签

    参考: https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000 GIT最流行的分布式版本 ...

  2. 『现学现忘』Git基础 — 8、Git创建本地版本库

    目录 1.Git版本库介绍 2.创建本地版本库 场景一:创建一个空的本地版本库. 场景二:项目中已存在文件时,创建该项目的本地版本库. 场景三:在GitHub网站上创建仓库,克隆到本地. 1.Git版 ...

  3. [git]入门-创建版本库

    转载整理自:https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/0013743256 ...

  4. Git创建本地版本库

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

  5. Git(2):本地版本库的一些操作

    参考链接:https://www.cnblogs.com/zhuwq585/p/6390542.html

  6. Git的使用(2) —— 本地版本库的操作

    1. 向本地版本库中添加文件 注意:.git文件夹是本地版本库,包含.git文件夹的目录叫工作目录,要往本地版本库中添加文件,就必须将文件放在工作目录中. (1) 把文件添加到工作目录中. (2) 右 ...

  7. git版本控制工具(二)----本地版本库的常用操作

    ​[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/ ...

  8. Git学习(1)-本地版本库的创建

    我用的是Git-2.14.3-64-bit版本,在windows64位上运行的,把软件分享下链接:http://pan.baidu.com/s/1jIoZ7Xc 密码:13q2. 安装及配置自行百度, ...

  9. Git for Windows之推送本地版本库到远程仓库

    Git for Windows之基础环境搭建与基础操作中介绍了Git基本环境的构建与基本的操作.生成了一个本地git版本库,本文将介绍如何将这个版本库推送到远程仓库(码云,github也可以). 1. ...

随机推荐

  1. 时序数据库InfluxDB:简介及安装

    在性能测试过程中,对测试结果以及的实时监控与展示也是很重要的一部分.这篇博客,介绍下linux环境下InfluxDB的安装以及功能特点. 官网地址:influxdata 官方文档:influxdb文档 ...

  2. 从 0 到 1 实现 React 系列 —— 1.JSX 和 Virtual DOM

    看源码一个痛处是会陷进理不顺主干的困局中,本系列文章在实现一个 (x)react 的同时理顺 React 框架的主干内容(JSX/虚拟DOM/组件/生命周期/diff算法/setState/ref/. ...

  3. Java里的不能与无用.

    不能获取参数名 , 导致函数的参数名无用. 在MyBatis的方法里. 参数名是无法反射得到的. 导致必须使用注解,指定参数名. 这样的话. 参数名就没有了意义.

  4. Java this与super的仇与恨

    刚开始学习面向对象的时候,看到this和super觉得this就是指当前对象,super指最近的父级对象.觉得用处不大. 后来,随着学习的深入,看别人的代码越来越多,发现this和super的使用率贼 ...

  5. day01(计算机组成,进制,内存分布,操作系统)

    本周内容: 第一天: 计算机原理 操作系统 第二天: 编程语言 python入门:环境 - 编辑器 变量 基本数据类型 学习方法: 鸡汤 - 干货 wwwh : what  | why | where ...

  6. 访问网站出现 HTTP ERROR 500 该网页无法正常运作

    项目在本地环境配置好后访问出现如下图所示: 经过查看php日志文件发现问题在于数据库连接错误,如下图: 修改成本地的数据库用户名和密码,重启服务器即可正常访问.

  7. Web项目中出现乱码

    (不知道怎么写才好) 分两种情况: 1.如果是 get 方式 单独修改: new String(str.getBytes("原来的编码"), "想要的编码") ...

  8. Java Mail 实现第三方邮件发送功能

    1 创建一个用于发送邮件的类 package com.latiny.service; import java.io.IOException; import java.io.InputStream; i ...

  9. c语言提高第二天

    一.指针强化1.指针也是一种数据类型,指针变量也是一种变量,和int a本质是一样的 1)指针变量也是一种变量,也有空间,32位程序大小为4个字节 int *p = 0x1122; 2)*操作符,*相 ...

  10. idea下创建maven聚合(子父级)项目,多模块项目

    IDEA下Maven多模块项目介绍和搭建 idea 创建maven聚合项目简洁教程(手把手入门,通俗易懂) 本人使用的是: intelj idea 创建聚合项目(典型web项目,包括子项目util.d ...