笔记-git-基础使用

1.      git相关概念

  1. 工作区(Working Directory):

就是在电脑里能看到的目录,init后的当前目录就是一个工作区;

  1. 版本库(Repository):

工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。

Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD;

  1. HEAD表示当前版本,HEAD^表示前一个版本,HEAD^^表示前前版本;

2.      GIT客户端

2.1.    客户端配置管理

config 配置有system,global(用户级别) ,local(当前仓库)三个级别,顺序为system-》global-》local,底层配置会覆盖顶层配置,分别使用--system/global/local 可以定位到配置文件。

常用配置命令:

git config –global user.name “name”

git config –global user.email 123@163.com

git config –global core.editor <>

查看配置

git config –list

git config –global –list

git config –system –list

git config –local --list

2.2.    开始——获取仓库

1、 创建仓库

git init

初始化后,目录下会出现一个名为 .git 的目录,所有 Git 需要的数据和资源都存放在这个目录中。

2、 也可以clone

git clone https://github.com/libgit2/libgit2 mylibgit

3.      常用操作

3.1.    创建文件并提交到版本库

在当前目录下新增或修改文件后保存到版本库分为两步:

  1. git add将修改添加到暂存区;
  2. git commit [-m commit explain ] #提交说明不是必需项,但强烈建议每次提交写说明。

3.2.    查看暂存区

git status

git status –s #使用状态码表示文件状态

状态码解释:

A: 你本地新增的文件(服务器上没有)

C: 文件的一个新拷贝

D: 你本地删除的文件(服务器上还在)

M: 文件的内容或者mode被修改了

R: 文件名被修改了

T: 文件的类型被修改了

U: 文件没有被合并(你需要完成合并才能进行提交)

X: 未知状态(很可能是遇到git的bug了,你可以向git提交bug report)

?:未被git进行管理,可以使用git add file1把file1添加进git能被git所进行管理

3.3.    查看修改内容

有一个命令用于查看已修改部分:

git diff

git diff filename

这种是比较 工作区和暂存区

比较暂存区与最新本地版本库

git diff --cached  filename

比较工作区和最新版本

git diff HEAD filename

比较工作区与指定的 commit -id 的差异

git diff commit-id  filename

比较暂存区与指定 commit-id 的差异

git diff --cached commit-id  filename

比较两个 commit -id 的差异

git diff commit-id commit-id

3.4.    回退

版本回退

git log查看历史记录

git reset –hard commit_id回退版本

git reset

git reset –mixed:此为默认方式,不带任何参数的git reset,即时这种方式,它回退到某个版本,只保留源码,回退commit和index信息

git reset –-soft:回退到某个版本,只回退了commit的信息,换句话说只修改了HEAD指向,暂存和工作区没变;

git reset -–hard:彻底回退到某个版本,本地的源码也会变为上一个版本的内容,撤销的commit中所包含的更改被冲掉。

回退总结:

  1. 版本回退:git reset --hard commit_id
  2. 查看版本号git log,确定回退到哪个版本,HEAD^也是可以的
  3. git reflog,如果回退版本后后悔了,使用该命令查看命令历史,再使用reset回到新版本。

3.5.    撤消

  1. 工作区文件修改撤消:git checkout –file;
  2. 工作区文件修改后添加到了暂存区,想放弃修改,分两步:

git reset HEAD <file>

git checkout --file

  1. 已提交到版本库后撤消,参考版本回退。

3.6.    删除文件

一般是在工作区删除了某个文件,有两种可能:

  1. 确实需要删除,那么也需要在版本库中删除:

git rm filename

git commit

  1. 误删除,需要恢复:

git checkout --filename

3.7.    分支管理

分支里有一个概念叫指针,head就是指针,指向当前分支,一般是master;

新建分支:

想要新建一个分支并同时切换到那个分支上,你可以运行一个带有 -b 参数的 git checkout 命令:

$ git checkout -b iss53

Switched to a new branch "iss53"

它是下面两条命令的简写:

$ git branch iss53

$ git checkout iss53

切换回 master 分支了:

$ git checkout master

Switched to branch 'master'

修改分支iss53,然后将其合并回 master 分支,可以使用 git merge。

$ git checkout master

$ git merge dev1

可以使用带 -d 选项的 git branch 命令来删除分支:

$ git branch -d hotfix

git branch –v

git branch –a

3.8.    git merge

git merge有fast-Foward模式和no-ff模式:

  1. Fast-Forward:当前分支合并到另一分支时,如果没有分歧,就会直接移动指针;

举例来说,开发一直在m分支进行,新建一个dev的分支,并在其上提交;

回到m分支,此时m分支在创建dev分支后未进行新的提交。

此时的合并就是fast-forward。

  1. no-ff模式:--no-ff:不使用fast-forward方式合并,保留分支的commit历史

git merge --no-ff -m "commit描述" 要合并的分支名

推荐使用no-ff模式,可以留下commit记录,便于管理。

3.8.1.   冲突

当mater和dev各有新的提交后在合并时会产生冲突。

Git用<<<<<<<,=======,>>>>>>>标记出不同分支的内容,打开文件后冲突示例内容:

<<<<<<< HEAD

12.merge:change master

=======

11.merge: change branch dev1

>>>>>>> dev1

可以在修改后再add,commit

小结:

当Git无法自动合并分支时,就必须首先解决冲突。解决冲突后,再提交,合并完成。

解决冲突就是把Git合并失败的文件手动编辑为我们希望的内容,再提交。

用git log --graph命令可以看到分支合并图。

3.9.    远程仓库

3.9.1.   查看信息

git remote

git remote –v

git remote show <name> #查看详细信息

3.9.2.   添加

git remote add <shortname> <url>

3.9.3.   推送

语法:

git push <远程主机名> <本地分支名>:<远程分支名>

以下是一些示例:

$ git push origin master

上面命令表示,将本地的master分支推送到origin主机的master分支。如果master不存在,则会被新建。

如果省略本地分支名,则表示删除指定的远程分支,因为这等同于推送一个空的本地分支到远程分支。

$ git push origin :master

# 等同于

$ git push origin --delete master

上面命令表示删除origin主机的master分支。如果当前分支与远程分支之间存在追踪关系,则本地分支和远程分支都可以省略。

$ git push origin

上面命令表示,将当前分支推送到origin主机的对应分支。如果当前分支只有一个追踪分支,那么主机名都可以省略。

$ git push

如果当前分支与多个主机存在追踪关系,则可以使用-u选项指定一个默认主机,这样后面就可以不加任何参数使用git push。

$ git push -u origin master

上面命令将本地的master分支推送到origin主机,同时指定origin为默认主机,后面就可以不加任何参数使用git push了。

3.9.4.   fetch

git fetch:Download objects and refs from another repository

从远程仓库取回分支和分支信息。如果只想取回特定分支的更新,可以指定分支名。

git fetch <远程主机名> <分支名>

git fetch  origin master

取回来的分支可以可以在本地主机上访问(即使断网),有一点不同是在本地主机上"远程主机名/分支名"的形式读取。

比如:

git fetch 130

git checkout 130/dev

3.9.5.   拉取

pull:Fetch from and integrate with another repository or a local branch

取回远程主机分支的更新,再与本地的指定分支合并。

一般情况下这样使用:

git pull <远程主机名> <远程分支名>:<本地分支名>

比如,取回130主机的dev分支,与本地的dev_temp分支合并:

git pull 130 dev:dev_temp

如果远程分支是与当前分支合并,则冒号后面的部分可以省略。

$ git pull 130 dev

笔记-git-基础使用的更多相关文章

  1. 笔记-Git基础

    git配置 git config --global user.name "xxx" //配置用户名 git config --global user.email "xxx ...

  2. 《Pro Git》笔记2:Git基础操作

    第二章 Git基础 Git基础包括:版本库的创建和获取,文件添加修改提交等基本操作,状态查询,远程版本库管理和同步,打标签. 1.取得项目的Git版本库 基于Git的工作流要以Git版本库为基础,即可 ...

  3. Git基础教程(二)

    继续上篇Git基础教程(一),在开篇之前,先回顾一下上篇中的基本命令. 配置命令:git config --global * 版本库初始化:git init 向版本库添加文件:git add * 提交 ...

  4. Git 基础 —— 常用命令

    Git 基础学习系列 Git 基础 -- 安装 配置 别名 对象 Git 基础 -- 常用命令 Git 基础 -- 常见使用场景 Git基础 -- Github 的使用 git init 创建 Git ...

  5. Git基础和入门

    一.Git基础概念 Git功能简单概述 可以随时回滚到之前的代码版本(git reset --hard ): 协同开发时不会覆盖别人的代码(分支): 留下修改记录(git log): 发版时可以方便的 ...

  6. [转] Git 基础 - 打标签

    2.6 Git 基础 - 打标签 打标签 同大多数 VCS 一样,Git 也可以对某一时间点上的版本打上标签.人们在发布某个软件版本(比如 v1.0 等等)的时候,经常这么做.本节我们一起来学习如何列 ...

  7. Git基础操作

    配置秘钥 1.检查本机有没有秘钥 检查~/.ssh看看是否有名为d_rsa.pub和id_dsa.pub的2个文件. $ ~/.sshbash: /c/Users/lenovo/.ssh: Is a ...

  8. git基础及分支

    关于版本控制 git是一种分布版本控制系统,每一主机都保存了完整副本.必杀技是分支. 在Windows可安装git客户端msysgit. git基础 第一次看progit觉得有点不懂,不懂版本控制,一 ...

  9. Git详解之二 Git基础

    Git 基础 读完本章你就能上手使用 Git 了.本章将介绍几个最基本的,也是最常用的 Git 命令,以后绝大多数时间里用到的也就是这几个命令.读完本章,你就能初始化一个新的代码仓库,做一些适当配置: ...

  10. 2.4 Git 基础 - 撤消操作

    2.4 Git 基础 - 撤消操作 撤消操作 任何时候,你都有可能需要撤消刚才所做的某些操作.接下来,我们会介绍一些基本的撤消操作相关的命令.请注意,有些撤销操作是不可逆的,所以请务必谨慎小心,一旦失 ...

随机推荐

  1. shell脚本学习(2)比较两个数字大小

    注意:shell中对比字符串只能使用==.<.>.!=.-z.-n.对比字符串时,末尾一定要加上x(或者a.b等)一个字符,因为if [ $1x == "ab"x ]时 ...

  2. Python模块与函数

    python的程序由包(package).模块(module)和函数组成.模块是处理某一类问题的集合,模块由函数和类组成,包是由一系列模块组成的集合.包必须至少包含一个__init__.py文件,该文 ...

  3. Python基本数据类型(一)

    一.int的函数说明(部分函数Python2特有,Python3已删除,部分函数Python3新增:) class int(object): """ int(x=0) - ...

  4. 第二章 LCD液晶显示屏&声控装置&播放音乐&遥控器

    这节我将带大家了解亮宁机器人编程的基础部分. LCD液晶显示屏 LCD液晶显示屏是在实现某种功能和调试中不可缺少的部分,接下来我带大家学习,如何使用LCD液晶显示屏. 首先我们把LCD液晶显示屏插入主 ...

  5. mysql数据库 thinkphp连贯操作where条件的判断不正确的问题

    前两天一直写一个基于thinkphp的东西,遇到从mysql数据库里select数据,where条件一直出现问题的情况.直接上代码: $history = M('history'); $suerId ...

  6. IOS 弹框AlterView的使用(IOS8.0以前使用)UIAlertController(IOS9.0使用)

    #pragma mark - 代理方法 - (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath ...

  7. POJ-1840 Eqs---二分

    题目链接: https://vjudge.net/problem/POJ-1840 题目大意: 给出一个5元3次方程,输入其5个系数,求它的解的个数 其中系数 ai∈[-50,50]  自变量xi∈[ ...

  8. Poj(1789),最小生成树,Prim

    题目链接:http://poj.org/problem?id=1789 还是套路. #include <stdio.h> #include <string.h> #define ...

  9. ibator自动代码生成

    首先,强烈推荐一篇文章,介绍的特详细 http://www.iteye.com/topic/821983 1. 插件安装 http://blog.csdn.net/rchm8519/article/d ...

  10. Filter,一种aop编程思想的体现

    一.filter简介 filter是Servlet规范里的一个高级特性,只用于对request.response的进行修改. filter提出了FilterChain的概念,客户端请求request在 ...