• 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 不能带文件名)

  • 相关阅读:
    cocos2d-x simpleGame 0
    cocos2d-x 下的HelloWorld
    cocos2d-x windows 配置
    算术入门之加减乘除
    计算摄氏温度
    输出倒三角图案
    厘米换算英尺英寸
    多文件模块的学生信息库系统
    GPS数据处理
    单词长度
  • 原文地址:https://www.cnblogs.com/nthforsth/p/12228414.html
Copyright © 2020-2023  润新知