一、Git特点

1.直接快照,而非比较差异

  Git只关心文件数据的整体是否发生变化,而不关心具体文件及其内容发生了那些变化。也就是说Git在保存文件时,每次只会在上一次版本基础上保存那些变化的文件,为为变化的文件不会再次被保存。

2.几乎所有的操作都可本地执行

  这些操作包括查看历史记录,回滚,对比差异都是直接操作本地数据库,而无须联网。代码提交,更新也无需连接远程库,直接提交到本地仓库,等到有网时才同步到远程库。

二、Git三种状态

已修改(modified):工作区的文件被修改后,为该状态,表明只是修改了工作区的文件。

已暂存(staged):将工作区已修改的文件添加到暂存区(add),这时Git中的文件并没有变化。

已提交(committed):将暂存区文件提交到Git库(commit),为该状态,这时Git库中的文件才被更改。

三、安装Git

windows:直接去git官网上下载客户端安装

Linux,如Ubuntu

apt-get install git

四、初次运行配置

git config --global user.name "jack"

git config --global user.email "123@163.com"

五,创建本地仓库

1.去到一个目录下,执行git init,当前目录下会出现一个.git目录,这里就是git本地仓库

2.从远程git仓库克隆一个到本地

git clone git://github.com/greit.git

本地目录会新建一个"greit"的目录,其中内含一个.git目录,说明已经把远程一个名为greit的git仓库克隆到本地,如果想自定义本地仓库名,在上面的url后加上自定义名称

3.查看当前文件状态,会显示有哪些文件未跟踪,未提交或者工作目录很干净,没有任何变化

git status

六、工作区操作

4.跟踪新文件,也就是将文件纳入git管理

git add [file or dir]

5.暂存已修改的文件,也是用add,git会根据文件状态选择使用add的那个功能

git add [file]

注意:处于暂存状态的文件,如果更改了,需要再次add

6.忽略某些文件

 某些文件不想git管理,又不想git老提示未跟踪该文件,就可以选择创建一个.gitignore文件来忽略指定的文件,如

cat .gitignore

*.[oa]    #忽略所有以.o或.a结尾的文件

*~      #忽略所有以~结尾的文件

!lib.a     #lib.a除外

/TODO    #仅忽略项目根目录下的TODO文件,不包括子目录的TODO文件

build/     #忽略build/目录下的所有文件

doc/*.txt   #忽略doc目录下所有txt文件,但不包括doc目录的子目录

7.当前文件(已修改未暂存)与暂存区快照之间的差异

git diff

已暂存的文件与上次提交时快照的差异

git diff --cached   或  -- staged

8.提交更新

git commit

9.移除文件,

从暂存区移除并从工作区删除

git rm [file]

从暂存区移除但不从工作区删除

git rm --cached [file]

10.撤销操作

  修改最后一次提交,其实就是再次提交的意思

  git commit --amend

  取消已暂存的文件,让他回到未暂存的状态

  git reset HEAD [file]

  取消对文件的修改,注意该命令会不会保留刚才的修改,一般建议回退

  git checkout -- [file]

记住:任何已经提交到Git的都可以被恢复,包括已删除的分支,只有未提交的才可能找不回来

七.远程仓库

 1.更新操作

  不合并到当前工作分支:git fetch [远程仓库名]

  自动合并到当前工作分支:git pull [远程仓库名]

 2.推送操作

  git push [远程仓库名] [分支名]    #远程仓库名默认origin 分支名默认master

  

Git学习笔记(1)的更多相关文章

  1. Git学习笔记与IntelliJ IDEA整合

    Git学习笔记与IntelliJ IDEA整合 一.Git学习笔记(基于Github) 1.安装和配置Git 下载地址:http://git-scm.com/downloads Git简要使用说明:h ...

  2. Git学习笔记(10)——搭建Git服务器

    本文主要记录了Git服务器的搭建,以及一些其他的配置,和最后的小总结. Git远程仓库服务器 其实远程仓库和本地仓库没啥不同,远程仓库只是每天24小时开机为大家服务,所以叫做服务器.我们完全可以把自己 ...

  3. Git学习笔记(四)

    一.忽略特殊文件 在Git工作区的根目录下创建一个特殊的.gitignore文件,然后把要忽略的文件名填进去,Git就会自动忽略这些文件. 不需要从头写.gitignore文件,GitHub已经为我们 ...

  4. git 学习笔记6--remote & log

    git 学习笔记6--remote & log 创建SSH Keys ssh-keygen -t rsa -C "1050244110@qq.com" 本地关联远程 git ...

  5. Git学习笔记---协作的一般流程

    一般的操作流程 1.pull 王小坤与另一个同事张大炮一起开发一个项目,张大炮昨天修改了数据库读写的api,优化了执行速度,并把read()函数改名成了Read(),下午下班之前把这些代码push到服 ...

  6. 【转帖】Git学习笔记 记录一下

    本文内容参考了廖雪峰老师的博文,并做了适当整理,方便大家查阅. 原帖地址 https://wangfanggang.com/Git/git/ 常用命令 仓库初始化 - git init 1 git i ...

  7. [转]Git学习笔记与IntelliJ IDEA整合

    Git学习笔记与IntelliJ IDEA整合 一.Git学习笔记(基于Github) 1.安装和配置Git 下载地址:http://git-scm.com/downloads Git简要使用说明:h ...

  8. GIT学习笔记(1):创建版本库

    GIT学习笔记(1):创建版本库 创建版本库 1.创建合适目录并初始化为仓库 版本库即需要交由Git进行版本控制的目录,其下所有文件的修改.删除,Git都能跟踪还原. 说明:初始化后,当前目录下会多出 ...

  9. GIT学习笔记(5):变基

    GIT学习笔记(5):变基rebase 变基 引入变基 在Git中整合来自不同分支的修改主要有两种方法:merge以及rebase. 整合分支最容易的方法是merge,他会把两个分支的最新快照以及两者 ...

  10. GIT学习笔记(4):远程分支

    GIT学习笔记(4):远程分支 远程分支 远程分支是什么 远程分支是对远程仓库中的分支的索引.它们是一些无法移动的本地分支:只有在GIT进行网络交互时才会更新.远程分支就是书签,提醒着你上次连接远程仓 ...

随机推荐

  1. Array.prototype.filter()

    1. filter() 方法:创建一个新的数组,新数组中的元素是通过检查指定数组中符合条件的所有元素 ——filter() 不会对空数组进行检测 ——filter() 不会改变原始数组 2. 语法: ...

  2. 第九组 通信3班 063 自反ACL

    一.拓扑图 R4为外网,R2和R3为内网. 二.地址表 Device Interface IP address R1 F 0/0 10.1.63.1 F 0/1 14.1.63.1 R2 F 0/0 ...

  3. Linux服务器上安装openoffice,以及安装字体文件

    1.安装openoffice (1)将openoffice的linux安装包放到linux指定的文件下(一般放在opt下) (2)在安装包的目录下执行命令:tar -zxvf 对应的压缩包名字 (3) ...

  4. C学习笔记-数据类型

    常量 在程序中不可变化的量,也就不可赋值 常用两种定义方式,#define和const 另外还有一个字符串常量 define #define MAX 100 #define在预编译的时候,其实也是做的 ...

  5. DAY 吐

    今天所学: 一,Linux的文件和目录管理 #1 cd( 变更用户所在目录)直接运行cd会进入root的/root下,后面跟目录名,会进入指定目录下( 后面只能是目录名,不能跟文件名). #2 pwd ...

  6. C#ModBus Tcp

    C#ModBus Tcp 报文解析   上一篇博客已经完成 C#ModBus Tcp Master的实现 本篇主要对不同的功能码所发出的报文进行解析(包括请求报文及响应报文) 读操作 功能码 0x01 ...

  7. jQuery之克隆事件--clone()与clone(true)区别

    clone()与clone(true)同为克隆 clone()表示复制标签本身, clone(true)会将标签绑定的事件一起复制 来看案例: <!DOCTYPE html> <ht ...

  8. [目标检测] 从 R-CNN 到 Faster R-CNN

    R-CNN 创新点 经典的目标检测算法使用滑动窗法依次判断所有可能的区域,提取人工设定的特征(HOG,SIFT).本文则预先提取一系列较可能是物体的候选区域,之后仅在这些候选区域上用深度网络提取特征, ...

  9. Similar String Groups

    Two strings X and Y are similar if we can swap two letters (in different positions) of X, so that it ...

  10. hanlp添加自定义字典的步骤介绍

      本篇分享一个hanlp添加自定义字典的方法,供大家参考! 总共分为两步: 第一步:将自定义的字典放到custom目录下,然后删除CustomDicionary.txt.bin,因为分词的时候会读这 ...