Git学习笔记(1)

一、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 "[email protected]"

五,创建本地仓库

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

  

时间: 2024-07-29 00:12:36

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

Git 学习笔记

Git 学习笔记 本文整理参考廖雪峰的 Git 教程, 整理 Git 学习笔记, 用于 Git 常用命令速查:常用命令用彩色标注! Git学习笔记 $ git config --global user.name "Your Name" 配置本机所有仓库的用户名 $ git config --global user.email "[email protected]" 配置本机所有仓库的Email地址 $ git init 初始化一个Git仓库 $ ls -ah 查看隐

Git学习笔记(二)

本次学习的是 版本回退 基本命令: 查看提交历史      git log 版本回退            git reset 查看每一次的命令 git reflog 具体步骤: 添加一句话到readme.txt中,并提交到Git库中. . readme.txt在Git中目前有三个版本: 按提交时间先后顺序排列如下: 第一个:wrote a readme.txt 第二个:add distrubuted 第三个:add difficulties 如果版本过多的话,根本记不住,只能查看使用命令git

Git 学习笔记<简介与安装> (一)

Git,开源中国以及GitHub所使用的系统, Is A 一个分布式版本控制系统 Be Used to 为团队合作写代码提供方便的管理系统.几乎满足你所有关于合作写代码的幻想. Has 本地端:工作区.版本库 (版本库还含有一个暂存区) 远程仓库:版本库(用来储存版本库的服务器) How To Install Linux: 首先,先输入git,看看是否安装Git: $ gitThe program 'git' is currently not installed. You can install

Git学习笔记总结和注意事项

一.Git简介 Git是目前世界上最先进的分布式版本控制系统,其特点简单来说就是:高端大气上档次! 二.Windows上Git安装 最早Git是在Linux上开发的,很长一段时间内,Git也只能在Linux和Unix系统上跑.不过,慢慢地有人把它移植到了Windows上.现在,Git可以在Linux.Unix.Mac和Windows这几大平台上正常运行了. msysgit是Windows版的Git,从http://msysgit.github.io/下载,然后按默认选项安装即可.安装完成后,在开

Git 学习笔记<远程仓库与标签管理> (四)

什么是远程仓库? 就像第一章介绍的那样,远程仓库可以储存你编写的所有源码和资源文件. 甚至也可以当网盘使,不过当然有很多契合git管理文本的特性. 下面就要以 github 为示例远程仓库进行介绍.  (也可以自己弄一台服务器作远程仓库). 创建仓库 在主页找到 +New repository 或者右上角的加号里有.输入名字 描述 然后没钱只能public就能确定了.然后呢,点名字打开你的仓库.(主页右下角可以找到) 关于与远程仓库的连接 首先你打开你的保险箱得先证明身份吧,不然我怎么知道你是客

【版本控制】git学习笔记(二)

关于git的基本使用请阅读上篇博文内容,[版本控制]git学习笔记(一). 1.远程仓库 Git是分布式版本控制系统,同一个Git仓库,可以分布到不同的机器上.怎么分布呢?最早,肯定只有一台机器有一个原始版本库,此后,别的机器可以"克隆"这个原始版本库,而且每台机器的版本库其实都是一样的,并没有主次之分. 你肯定会想,至少需要两台机器才能玩远程库不是?但是我只有一台电脑,怎么玩? 其实一台电脑上也是可以克隆多个版本库的,只要不在同一个目录下.不过,现实生活中是不会有人这么傻的在一台电脑

Git学习笔记(四)

一.忽略特殊文件 在Git工作区的根目录下创建一个特殊的.gitignore文件,然后把要忽略的文件名填进去,Git就会自动忽略这些文件. 不需要从头写.gitignore文件,GitHub已经为我们准备了各种配置文件,只需要组合一下就可以使用了.所有配置文件可以直接在线浏览:https://github.com/github/gitignore .gitignore文件本身要放到版本库里,并且可以对.gitignore做版本管理! 二.配置别名 $ git config --global al

git学习笔记(非常乱)

gitwiki 我是一个php程序员,但是我还是用windows开发环境.我不争气. 下载 git bash(windows环境下的git) 安装完之后设置用户名和邮箱 git config --global user.name "linjingxiong" git config --global user.email "[email protected]" 基本的命令: git init cd /d/../../  进入D盘的某目录 pwd          列出

Git 学习笔记<分支管理> (三)

分支是什么? 分支就像树分出的树枝,不同的是,它们之间可以互相合并. 将版本的推进想象成一个链表的伸长:  version 1.0 ==> version 2.0 ==>version3.0  . master是主要的分支基本上用于发布产品.你可以从master分出一个dev,在上面创建新功能,或者修bug然后调试.最后再合并到master里面.就像下面这样. master分支:  version 1.0=========>version 2.0===... \            

Git学习笔记(8)——标签管理

本文主要记录的Git标签的作用.标签的多种创建方式,以及标签的删除,与推送,和使用GitHub的Fork参与别人的项目. 标签的作用 发布版本时,通常先在版本库中打一个标签,这样,就唯一确定了打标签时刻的版本.无论什么时候,取某个标签的版本,就是把那个打标签的时刻的历史版本取出来.所以,标签也是版本库的一个快照.Git的标签虽然是版本库的快照,但其实它就是指向某个commit的指针(跟分支很像,但是分支可以移动,标签不能移动),所以,创建和删除标签都是瞬间完成的. 创建标签 [email pro