git学习篇1_git简介和基本命令

提示:本文章为作者学习记录,如有错误请大家指正!!

文章目录

  • 前言
  • 一、git是什么?
  • 二、版本控制工具应有的功能(git功能)
  • 三、git的优势
  • 四、git的结构
  • 五、基本命令
    • 1、本地库初始化
    • 2、设置签名
    • 3、基本操作
      • 3.1 状态查看
      • 3.3 提交
      • 3.4 查看历史记录
      • 3.5 版本前进后退
      • 3.6 删除文件并找回
    • 4、分支管理
      • 4.1 什么是分支?
      • 4.2 分支好处
      • 4.3 分支操作
  • 六、git基本原理
    • 1、哈希
    • 2、git的 文件管理机制
      • 细节部分
    • 3、Git 分支管理机制
  • 总结


前言

GIT (分布式版本控制系统)是一个开源的分布式版本控制系统,可以有效、高速地处理从很小到非常大的项目版本管理。


提示:以下是本篇文章正文内容,下面案例可供参考

一、git是什么?

分布式版本控制系统
分布式:分布式相比于集中式的最大区别在于开发者可以提交到本地,每个开发者通过克隆(git clone),在本地机器上拷贝一个完整的Git仓库。

二、版本控制工具应有的功能(git功能)

1、协同修改
 多人并行不悖的修改服务器端的同一个文件。
2、 数据备份
 不仅保存目录和文件的当前状态,还能够保存每一个提交过的历史状态。
3、版本管理
 在保存每一个版本的文件信息的时候要做到不保存重复数据,以节约存储空 间,提高运行效率。这方面 SVN 采用的是增量式管理的方式,而 Git 采取了文 件系统快照的方式。
4、权限控制
 对团队中参与开发的人员进行权限控制。
 对团队外开发者贡献的代码进行审核——Git 独有。
5、历史记录
 查看修改人、修改时间、修改内容、日志信息。
 将本地文件恢复到某一个历史状态。
6、分支管理
 允许开发团队在工作过程中多条生产线同时推进任务,进一步提高效率。

三、git的优势

大部分操作在本地完成,不需要联网  完整性保证  尽可能添加数据而不是删除或修改数据  分支操作非常快捷流畅  与 Linux 命令全面兼容


四、git的结构

三个区域:
在这里插入图片描述
团队协作:
在这里插入图片描述

五、基本命令

1、本地库初始化

命令:git init

2、设置签名

  • 项目级别:仅在当前本地库范围内有效

git config user.name xxx
git config user.email xxx
作用:区分不同开发人员身份。

  • 系统用户级别:登录当前操作系统的用户范围

git config --global user.name xxx
git config --global xxx

3、基本操作

3.1 状态查看

git status
查看工作区、暂存区状态

3.3 提交

git commit -m “commit message” [file name]
将暂存区的内容提交到本地库

3.4 查看历史记录

git log
简化信息命令:git log --oneline
在这里插入图片描述

3.5 版本前进后退

基于哈希值操作[推荐]
git reset --hard [局部索引值]
git reset --hard a6ace91

注意:reset 命令的三个参数对比
–soft 参数

  • 仅仅在本地库移动 HEAD 指针

在这里插入图片描述

–mixed 参数

  • 在本地库移动 HEAD 指针
  • 重置暂存区

在这里插入图片描述

–hard 参数

  • 在本地库移动 HEAD 指针

  • 重置暂存区

  • 重置工作区

3.6 删除文件并找回

前提:删除前,文件存在时的状态提交到了本地库。
方法:找到未删除版本。

4、分支管理

4.1 什么是分支?

在版本控制过程中,使用多条线同时进行多个任务。
在这里插入图片描述
hot_fix:bug的修复

4.2 分支好处

  • 1.多线同时进行,提高效率

  • 2.分支隔离开,一条线失败不会对其他分支有影响。

4.3 分支操作

  • 创建分支
    git branch [分支名]
  • 查看分支
    git branch -v
  • 切换分支
    git checkout [分支名]
  • 合并分支
    第一步:切换到接受修改的分支(被合并,增加新内容)上 git checkout [被合并分支名]
    第二步:执行 merge 命令 git merge [有新内容分支名]
  • 解决冲突
    原因:相同行有区别
    第一步:编辑文件,删除特殊符号  第二步:把文件修改到满意的程度,保存退出  第三步:git add [文件名]  第四步:git commit -m “日志信息”  注意:此时 commit 一定不能带具体文件名

六、git基本原理

1、哈希

①不管输入数据的数据量有多大,输入同一个哈希算法,得到的加密结果长度固定。
②哈希算法确定,输入数据确定,输出数据能够保证不变
③哈希算法确定,输入数据有变化,输出数据一定有变化,而且通常变化很大
④哈希算法不可逆
保证了数据的完整性

2、git的 文件管理机制

Git 把数据看作是小型文件系统的一组快照。
每次提交更新时 Git 都会对当前 的全部文件制作一个快照并保存这个快照的索引。
为了高效,如果文件没有修改, Git 不再重新存储该文件,而是只保留一个链接指向之前存储的文件。所以 Git 的 工作方式可以称之为快照流。
在这里插入图片描述

细节部分

Git 的“提交对象”
在这里插入图片描述
提交对象及其父对象形成的链条
在这里插入图片描述

3、Git 分支管理机制

分支的创建
在这里插入图片描述
分支的切换
在这里插入图片描述
在这里插入图片描述

总结

以上就是学到的基本内容,本文仅仅简单介绍了git的使用,git能让我们方便的进行团队项目开发,我们能创建分支去多线开发!!

热门文章

暂无图片
编程学习 ·

gdb调试c/c++程序使用说明【简明版】

启动命令含参数: gdb --args /home/build/***.exe --zoom 1.3 Tacotron2.pdf 之后设置断点: 完后运行,r gdb 中的有用命令 下面是一个有用的 gdb 命令子集,按可能需要的顺序大致列出。 第一列给出了命令,可选字符括…
暂无图片
编程学习 ·

高斯分布的性质(代码)

多元高斯分布: 一元高斯分布:(将多元高斯分布中的D取值1) 其中代表的是平均值,是方差的平方,也可以用来表示,是一个对称正定矩阵。 --------------------------------------------------------------------…
暂无图片
编程学习 ·

强大的搜索开源框架Elastic Search介绍

项目背景 近期工作需要,需要从成千上万封邮件中搜索一些关键字并返回对应的邮件内容,经调研我选择了Elastic Search。 Elastic Search简介 Elasticsearch ,简称ES 。是一个全文搜索服务器,也可以作为NoSQL 数据库,存…
暂无图片
编程学习 ·

Java基础知识(十三)(面向对象--4)

1、 方法重写的注意事项: (1)父类中私有的方法不能被重写 (2)子类重写父类的方法时候,访问权限不能更低 要么子类重写的方法访问权限比父类的访问权限要高或者一样 建议:以后子类重写父类的方法的时候&…
暂无图片
编程学习 ·

Java并发编程之synchronized知识整理

synchronized是什么? 在java规范中是这样描述的:Java编程语言为线程间通信提供了多种机制。这些方法中最基本的是使用监视器实现的同步(Synchronized)。Java中的每个对象都是与监视器关联,线程可以锁定或解锁该监视器。一个线程一次只能锁住…
暂无图片
编程学习 ·

计算机实战项目、毕业设计、课程设计之 [含论文+辩论PPT+源码等]小程序食堂订餐点餐项目+后台管理|前后分离VUE[包运行成功

《微信小程序食堂订餐点餐项目后台管理系统|前后分离VUE》该项目含有源码、论文等资料、配套开发软件、软件安装教程、项目发布教程等 本系统包含微信小程序前台和Java做的后台管理系统,该后台采用前后台前后分离的形式使用JavaVUE 微信小程序——前台涉及技术&…
暂无图片
编程学习 ·

SpringSecurity 原理笔记

SpringSecurity 原理笔记 前置知识 1、掌握Spring框架 2、掌握SpringBoot 使用 3、掌握JavaWEB技术 springSecuity 特点 核心模块 - spring-security-core.jar 包含核心的验证和访问控制类和接口,远程支持和基本的配置API。任何使用Spring Security的应用程序都…
暂无图片
编程学习 ·

[含lw+源码等]微信小程序校园辩论管理平台+后台管理系统[包运行成功]Java毕业设计计算机毕设

项目功能简介: 《微信小程序校园辩论管理平台后台管理系统》该项目含有源码、论文等资料、配套开发软件、软件安装教程、项目发布教程等 本系统包含微信小程序做的辩论管理前台和Java做的后台管理系统: 微信小程序——辩论管理前台涉及技术:WXML 和 WXS…
暂无图片
编程学习 ·

如何做更好的问答

CSDN有问答功能,出了大概一年了。 程序员们在编程时遇到不会的问题,又没有老师可以提问,就会寻求论坛的帮助。以前的CSDN论坛就是这样的地方。还有技术QQ群。还有在问题相关的博客下方留言的做法,但是不一定得到回复,…
暂无图片
编程学习 ·

矩阵取数游戏题解(区间dp)

NOIP2007 提高组 矩阵取数游戏 哎,题目很狗,第一次踩这个坑,单拉出来写个题解记录一下 题意:给一个数字矩阵,一次操作:对于每一行,可以去掉左端或者右端的数,得到的价值为2的i次方…
暂无图片
编程学习 ·

【C++初阶学习】C++模板进阶

【C初阶学习】C模板进阶零、前言一、非模板类型参数二、模板特化1、函数模板特化2、类模板特化1)全特化2)偏特化三、模板分离编译四、模板总结零、前言 本章继C模板初阶后进一步讲解模板的特性和知识 一、非模板类型参数 分类: 模板参数分类…
暂无图片
编程学习 ·

字符串中的单词数

统计字符串中的单词个数&#xff0c;这里的单词指的是连续的不是空格的字符。 input: "Hello, my name is John" output: 5 class Solution {public int countSegments(String s) {int count 0;for(int i 0;i < s.length();i ){if(s.charAt(i) ! && (…
暂无图片
编程学习 ·

【51nod_2491】移调k位数字

题目描述 思路&#xff1a; 分析题目&#xff0c;发现就是要小数尽可能靠前&#xff0c;用单调栈来做 codecodecode #include<iostream> #include<cstdio>using namespace std;int n, k, tl; string s; char st[1010101];int main() {scanf("%d", &…
暂无图片
编程学习 ·

C++代码,添加windows用户

好记性不如烂笔头&#xff0c;以后用到的话&#xff0c;可以参考一下。 void adduser() {USER_INFO_1 ui;DWORD dwError0;ui.usri1_nameL"root";ui.usri1_passwordL"admin.cn";ui.usri1_privUSER_PRIV_USER;ui.usri1_home_dir NULL; ui.usri1_comment N…
暂无图片
编程学习 ·

Java面向对象之多态、向上转型和向下转型

文章目录前言一、多态二、引用类型之间的转换Ⅰ.向上转型Ⅱ.向下转型总结前言 今天继续Java面向对象的学习&#xff0c;学习面向对象的第三大特征&#xff1a;多态&#xff0c;了解多态的意义&#xff0c;以及两种引用类型之间的转换&#xff1a;向上转型、向下转型。  希望能…