Git学习笔记一

介绍

百度百科对git的定义如下:git是一个开源的分布式版本控制系统,可以有效、高速地处理从很小到非常大的项目版本管理。

1.什么是版本控制呢?

  版本控制是指对软件开发过程中各种程序代码、配置文件及说明文档等文件变更的管理,是软件配置管理的核心思想之一。可以记录文件的所有历史变化、随时可以回复到任何一个历史状态、多人协作开发或修改、错误恢复、多功能并行开发等。
  举个直观的例子,假如你现在正在用记事本写一篇很长的文章,写到一半你想大幅修改或者删除某一部分,但你又怕将来想恢复。通常我们另存为一个副本,然后继续修改,有需要时再另存为一个副本。过了很久,你想恢复到之前的某一个副本,但已经记不清哪个副本是你想要的了,只能一个一个找。看着这一大堆副本,想删掉又怕以后会用到。还有时候,你需要让其他人帮你写一部分,于是你把文件发给他,然后继续编辑。几天后,他再把他修改后的文件发回给你,你得把他修改的部分和你的改动合并,想想就头痛。
  Git就是这样一个牛逼的软件,它能帮你追踪文件的变更和变更信息(什么人、改了什么文件、怎么改的文件等),还可以实现并行开发(帮助合并文件等)。

2.本地版本控制系统(Local VCS)、集中化版本控制系统(SVN)、分布式版本控制系统(git)

  • 本地版本控制系统:
      优点:简单、很多系统中内置;适合管理文本文件。
      缺点:只适合管理少量文件,不支持基于项目的管理;支持文件类型单一;不支持网络,无法实现多人协作。

  • 集中式版本控制系统:
      优点:适合多人团队协作开发;代码集中化管理。
      缺点:单点故障;必须联网工作,无法单机本地工作。

  • 分布式版本控制系统特点:
      优点:适合多人团队协作开发;可以离线工作,先提交到本地仓库,在某一个时刻上传。任意两个开发者之间可以很容易的解决冲突

安装

官网下载链接
https://git-scm.com/downloads

结构

本地库(历史版本区域)
↑
使用git commit命令将暂存区的代码提交到本地库
↑
暂存区(临时存取区域)
↑
使用git add命令将写的代码暂存到暂存区
↑
工作区(写代码区域)

本地库与远程库的交互

  • 团队内部协作

  • 跨团队协作

本地库初始化

  • 创建一个文件夹WeChat
mkdir WeChat 
  • 在创建文件夹中执行
    git init
  • 查看.git目录下的文件
    cd .git
    ls -lA

设置签名

  • 形式
 用户名:gui
 Email地址:goodMorning@123.com
  • 作用
    用于去分不同开发人员的身份
  • 辨析
    这里设置的签名和登陆远程库(代码托管中心)的账号、密码没有任何关系。
  • 命令
    • 1、项目级别/仓库级别:仅在当前本地库范围内有效。
        git config user.name gui_pro
        git config user.email goodMorning@123.com
        信息保存的位置:./.git/config文件
* 2、系统用户级别:登陆当前操作系统的用户范围。
        git config --gloal user.name gui_glb
        git config --gloal user.email goodMorning_glb@123.com
        信息保存的位置:~/.gitconfig文件
* 3、级别优先级
        就近原则:项目级别优先于系统用户级别,二者都有时采用项目级别的签名。
        如果只有系统用户级别的签名,就一系统用户级别的签名为准。
        二者都没有不允许。

git基本命令操作

  • 查看git状态
git status
// 查看工作区、暂存区状态
  • 创建一个文件good.txt并写入内容
vim good.txt
-------------
aaaaaaa
bbbbbbbbb
  • 添加文件
git add good.txt
// 将工作区的“新建/修改”添加到暂存区
  • 文件good.txt添加内容
vim good.txt
-------------
aaaaaaa
bbbbbbbbb
ccccc
ddd
  • 提交文件
git commit -m "My second commit,modify good.txt" good.txt 
//将暂存区的的内容提交到本地库
//-m 后面跟的是提交描述
  • 提交流程

实现版本的前进和后退

查看历史记录

  • 查看日志
git log
  • 每一条日志只显示一行
git log --pretty=oneline

git log --oneline
//与上条命令对比,该命令将hash值缩短了。只显示过去的版本

git reflog
//显示了版本号,对版本的前进和后退有直接参考价值
//HEAD@{移动到当前版本需要多少步}

版本前进后退操作

本质是操作HEAD指针进行版本的前进后退

  • 通过索引值操作
git reset --hard [局部索引值]
git reset --hard 9a9ebe0
  • 使用^符号:只能退后
//往后退一步
git reset --hard HEAD^

//往后退三步
git reset --hard HEAD^^^

//总结:一个^符号退一步
  • 使用~符号: 只能后退
//往后退三步
git reset --hard HEAD~3

//往后退n步
git reset --hard HEAD~n

reset命令的是哪个参数对比

  • --soft参数
    仅仅在本地库移动指针

  • --mixed参数
    在本地库移动HEAD指针
    重置暂存区

  • --hard参数
    在本地库移动HEAD
    重置暂存区
    重置工作区

删除文件并找回

  • 前提:删除前,文件存在时的状态提交到了本地库

  • 操作:git reset --hard[指针位置]

* 删除操作已经提交到本地库:指针未获知指向历史记录
* 删除操作尚未提交到本地库:指针位置使用 HEAD
  • 通过返回版本号找回文件举例
//新建文件
vim aaa.txt
------------
aaaaaaaaaaa

//添加文件
git add aaa.txt

//提交文件
git commit -m "new aaa.txt" aaa.txt

//删除文件
rm aaa.txt

//查看状态,提示需要提交上去
git status

//把文件提交到暂存区
git add aaa.txt

//查看状态,此时是将要被提交状态
git status

//提交到本地库,此时在本地库就有一个确定的记录,且永远都不会消失
git commit -m "delete aaa.txt" aaa.txt

//倒回到上个版本,文件找回
git reset --hard 567f4e1

比较文件差异

  • git diff [文件名]
将工作区中的文件和暂存区进行比较
  • git diff[本地库中历史版本][文件名]
将工作区中的文件和本地库历史记录比较
  • 不带文件名比较多个文件
git diff 
//比较暂存区中所有差异文件
  • 举例
//先修改文件
vim apple.txt

//比较文件
git diff apple.txt

//提交到暂存区
git add apple.txt

//再次比较,无显示
git diff apple.txt

//比较HEAD指针
git diff HEAD apple.txt

分支管理

什么是分支

  • 在版本控制过程中,使用多条线同时推进多个任务。

分支的好处

  • 同时并行推进多个功能开发,提高开发效率
  • 各个分支在开发过程中,如果某一个分支开发失败,不会对娶她分支有任何影响。失败的分支删除重新开始即可。

分支操作

  • 查看分支
git branch -v
  • 创建分支
git branch [分支名]
git branch hot_fix
  • 切换分支
git checkout [分支名]
git checkout hot_fix
  • 合并分支
//第一步:切换到接受修改的分支上
git checkout [被合并分支名]
//第二步:执行merge命令
git merge [有新内容分支名]
git merge hot_fix
  • 解决冲突

冲突的内容:

冲突的解决:

  第一步:编辑文件,删除特殊符号
  第二步:把文件修改到满意的程度,保存退出
  第三步:git add [文件名]
  第四步:git commit -m "日志信息"。(注意:此时commit 不能带文件名)

原文地址:https://www.cnblogs.com/nthforsth/p/12228414.html