当前位置: 首页 > news >正文

Git【成神路】

目录

1.为啥要学git啊?😕😕😕

2.版本控制软件的基本功能 🤞🤞🤞

3.集中式版本控制 🤶🤶🤶  

4.分布式版本控制😎😎😎

 5.Git的下载与安装 😭😭😭

6.GitHubDesktop使用 😁😁😁😁

7.多人协作分支与合并😎😎😎

8.idea集成gitee 😕😕😕

8.1安装插件

8.2选择gitee 并登录

9.版本号🤞🤞🤞

10.git指令 😳😳😳

10.1仓库操作

10.2文件操作

10.3分支操作

10.4标签操作

10.5远程仓库


1.为啥要学git啊?😕😕😕

Git 是目前最流行的版本控制工具之一,它可以帮助开发团队更好地管理代码、协作开发、记录版本变化、合并代码等等。学习 Git 可以使你更好地参与到开源项目中,也可以提高团队协作的效率,更好地管理自己的代码库。

 

Git是一个分布式版本控制工具,通常用来对软件开发过程中的源代码文件进行管理。通过Git仓库来存储和管理这些文件,Git 仓库分为两种:

  • 本地仓库:开发人员自己电脑上的Git仓库
  • 远程仓库:远程服务器上的 Git 仓库 
  • commit:提交,将本地文件和版本信息保存到本地仓库
  • push:推送,将本地仓库文件和版本信息上传到远程仓库
  • pull:拉取,将远程仓库文件和版本信息下载到本地仓库 

2.版本控制软件的基本功能 🤞🤞🤞

  • 1.保存和管理文件
  • 2.提供客户端工具进行访问
  • 3.提供不同版本文件的比对功能

3.集中式版本控制 🤶🤶🤶  

  • 集中式版本控制,多人协作可能导致文件覆盖问题----文件冲突 
  • Visual SourceSafe美国微软公司出品的版本控制系统,简称VSS 集中式版本控制系统
  • 上锁解决~但效率较低

 

  •  Concurrent Versions System老牌的版本控制系统,它是基于客户端/服务器的行为使得其可容纳多用户,构成网络也很方便,简称为CVS 
  • Subversion开放源代码的版本控制系统,通过采用分支管理系统的高效管理,简而言之就是用于多个人共同开发同一个项目,实现共享资源,实现最终集中式的管理

规定约束,进行比对,记录下每次操作 ~如果对同一行操作依然冲突

4.分布式版本控制😎😎😎

分布式版本控制(Distributed Version Control,简称DVCS)是一种管理代码版本的方式,它与集中式版本控制(Centralized Version Control,简称CVCS)相比,分布式版本控制是在每个开发者本地都拥有完整的代码仓库(repository),而不是像集中式版本控制那样所有开发者都使用中央服务器上的代码仓库。

特点:

  1. 每个开发者都有一个完整的代码仓库,包含所有历史版本的代码库,不依赖于中央服务器,可在离线状态下进行开发。

  2. 开发者可以在本地进行代码的修改、提交、合并等操作,不需要等待中央服务器的响应。

  3. DVCS 支持分支(branch)管理,可以轻松地创建、合并分支,便于团队协作和业务流程控制。

  4. DVCS 提供了更完善的代码审核(code review)机制,开发者可以创建自己的分支,进行代码修改,在满足要求后提交到主干分支。

 5.Git的下载与安装 😭😭😭

下载地址:Git - Downloads (git-scm.com)

当时打不开,小张又找的安装包😭😭😭😭😭😭😭

6.GitHubDesktop使用 😁😁😁😁

  • 在仓库路径创建文件,会与.git进行比较,看是否存在 ~

  • 如果删除仓库路径中的文件,但是.git中没有被删除,也需要提交~

7.多人协作分支与合并😎😎😎

8.idea集成gitee 😕😕😕

8.1安装插件

8.2选择gitee 并登录

9.版本号🤞🤞🤞

Git版本号是由40个十六进制字符组成的字符串,通常被称为“SHA-1哈希值”。它是由Git版本控制系统为每个提交生成的唯一标识符,用于跟踪代码的历史和变化。

  • 1.避免合并时版本冲突
  • 2.定位仓库中文件的位置(前两位文件夹名,后面的是文件名)

在git自带的控制台可以查询文件信息

分支

git的三个区域

10.git指令 😳😳😳

10.1仓库操作

  • (先进入创建的文件夹) 通过命令,把这个目录变成git可以管理的仓库
git init 
  • 通过命令克隆远程仓库到本地 并重命名
git clone +远程仓库地址 新的文件名
  •  全局配置操作者信息
 git config --globle user.name xiaozhanggit config --globle user.email 31@qq.com

10.2文件操作

  • 查看暂存区的状态
git status

当添加文件工作区后,再次查询,会提示 Untracked files

  • 将文件添加到暂存区
git add b.txt

  • 将文件移缓存区移除到工作区 
git rm --cached 文件名
  • 将缓存区的文件添加到.git存储区域 
git commit -m 信息
  • 查看历史记录
git log   查看所有
git log --oneline 简化查询
  • 如果工作区的文件误删除了,可以把.git存储区的文件恢复
git restore 文件名
  • 如果工作区的文件误删了,又提交到了.git存储区,使用版本重置
  • 这种操作会导致误删除的操作丢失
git reset  --hard 上一个版本的序号id
  • 既可以恢复文件,也可以恢复误删除的操作
git revert 删除操作的序列号id

10.3分支操作

  • 先提交,才能创建分支
git branch 分支名称
  • 查看有多少个分支
git branch -v
  • 切换分支
git checkout 要切换的分支名称
  • 创建分支,并切换到该分支
git checkout -b 要创建并切换的分支名称
  • 删除分支
git branch -d 要删除的分支名称
  • 合并文件
master merge 要合并的分支名称

注意:合并后会出现文件冲突,需要手动解决,然后再次提交

10.4标签操作

  • 查看标签
git tag
  • 新增标签
git tag 标签名  要添加标签的序号id
  • 删除标签
git tag -d 标签名

10.5远程仓库

  • 上传到远程仓库
git push origin

这里的url使用的gitee中的SSH

当 push 到远程仓库时,会下面报错:

Are you sure you want to continue connecting (yes/no/[fingerprint])? yes
Warning: Permanently added 'gitee.com' (ED25519) to the list of known hosts.
git@gitee.com: Permission denied (publickey).
fatal: Could not read from remote repository.

 因为我们使用的是SSH,这种方式需要提供安全认证

  • 生成安全认证书 
ssh-keygen -t rsa -C SSH地址
  • 接着一直回车下去,然后在你的:C盘-用户-.ssh中有个id_rsa.pub,拷贝里面的所有然后到你的gittee

         再次 push 就会推送到远程仓库

  • 从远程拉取文件
git pull origin

相关文章:

Git【成神路】

目录 1.为啥要学git啊?😕😕😕 2.版本控制软件的基本功能 🤞🤞🤞 3.集中式版本控制 🤶🤶🤶 4.分布式版本控制😎😎😎 …...

文件操作详解

文件操作详解 一:文件相关概念1:问什么使用文件2:什么是文件???2.1:程序文件2.2数据文件 二:文件的打开和关闭1:流的定义2:标准流3:文件指针 一&a…...

模块 A:web理论测试

模块 A:理论测试 任务一:单选题 1.为 EMP 表的 namesalary 字段创建名为 emp name salary idx 的校复习接课 name 字段升序, salary 字段降序的复合索引的 SQL 语句是? B A: CREATEINDEX emp name salary idx ON EMP(namesalary) B: …...

git rebase冲突说明(base\remote\local概念说明)

主线日志及修改 $ git log master -p commit 31213fad6150b9899c7e6b27b245aaa69d2fdcff (master) Author: Date: Tue Nov 28 10:19:53 2023 08004diff --git a/123.txt b/123.txt index 294d779..a712711 100644 --- a/123.txtb/123.txt-1,3 1,4 123 4^Mcommit a77b518156…...

函数式接口的妙用,让异步执行更简单

你是否曾经遇到过在SpringBoot中Async注解无法正常工作的问题?今天,我们用函数式接口来解决这个问题。 一、什么是函数式接口? 函数式接口(Functional Interface)是 Java 8 中引入的一个概念,是指只包含一…...

读书笔记:《More Effective C++》

More Effective C Basics reference & pointer reference 必定有值,pointer 可以为空reference 声明时必须定义,必须初始化reference 无需测试有效性,pointer 必须测试是否为 nullreference 可以更改指向对象的值,但是无法…...

手写VUE后台管理系统6 - 支持TS声明文件.d.ts

TS 使用声明文件进行类型定义。 配置 在 tsconfig.json 文件中,找到 include 属性,添加 "src/**/*.d.ts",表示 src 目录下的所有 .d.ts 文件都会被自动加载。 添加后内容如下 "include": ["src/**/*.ts",&…...

第八天:信息打点-系统端口CDN负载均衡防火墙

信息打点-系统篇&端口扫描&CDN服务&负载均衡&WAF防火墙 一、知识点 1、获取网络信息-服务器厂商: 阿里云,腾讯云,机房内部等。 网络架构: 内外网环境。 2、获取服务信息-应用协议-内网资产: FTP…...

一款充电桩解决方案设计

一、基本的概述 项目由IP6536提供两路5V 1.5A 的USB充电口,IP6505提供一路最大24W的USB快充口支持QC3.0 / DCP / QC2.0 / MTK PE1.1 / PE2.0 / FCP / SCP / AFC / SFCP的快充协议,电池充电由type-C输入经过IP2326输出最高15W快充对电池进行充电&#xf…...

Leetcode 2953. Count Complete Substrings

Leetcode 2953. Count Complete Substrings 1. 解题思路2. 代码实现 题目链接:2953. Count Complete Substrings 1. 解题思路 这一题麻烦的点就在于说有两个限制条件,但是好的点在于说这两个限制条件事实上是相互独立的。 因此,我们可以通…...

【Python-第三方库-pywin32】随笔- Python通过`pywin32`获取窗口的属性

Python通过pywin32获取窗口的属性 基础 获取所有窗口的句柄 【代码】 import win32guidef get_all_windows():hWnd_list []win32gui.EnumWindows(lambda hWnd, param: param.append(hWnd), hWnd_list)print(hWnd_list)return hWnd_list【结果】 获取窗口的子窗口句柄 【代…...

Flask使用线程异步执行耗时任务

1 问题说明 1.1 任务简述 在开发Flask应用中一定会遇到执行耗时任务,但是Flask是轻量级的同步框架,即在单个请求时服务会阻被塞,直到任务完成(注意:当前请求被阻塞不会影响到其他请求)。 解决异步问题有…...

zabbix监控nginx

zabbix是什么 web界面提供的一种可视化的监控服务软件 以分布式的方式系统监控以及网络监控,硬件监控等等开源的软件 zabbix的架构 1、c/s模式 客户端和服务端,zabbix server服务端 zabbix agent 客户端 2、通过B/S B是浏览器 S服务端,通…...

【CVE-2023-49103】ownCloud graphapi信息泄露漏洞(2023年11月发布)

漏洞简介 ownCloud owncloud/graphapi 0.2.x在0.2.1之前和0.3.x在0.3.1之前存在漏洞。graphapi应用程序依赖于提供URL的第三方GetPhpInfo.php库。当访问此URL时,会显示PHP环境的配置详细信息(phpinfo)。此信息包括Web服务器的所有环境变量&a…...

可视化数据库管理客户端:Adminer

简介:Adminer(前身为phpMinAdmin)是一个用PHP编写的功能齐全的数据库管理工具。与phpMyAdmin相反,它由一个可以部署到目标服务器的文件组成。Adminer可用于MySQL、PostgreSQL、SQLite、MS SQL、Oracle、Firebird、SimpleDB、Elast…...

Python----字典练习

相关链接:Python---字典的增、删、改、查操作_python中字典的增删改查-CSDN博客 Python---字典---dict-CSDN博客 Python---引用变量与可变、非可变类型-CSDN博客 重点: 字典中的 key (就是键)可以是很多数据类型(…...

CentOS 部署 WBO 在线协作白板

1)WBO 白板工具介绍 1.1)WBO 白板简介 WBO 是一个自由和开源的在线协作白板。它允许多个用户同时在一个虚拟的大型白板上画图。该白板对所有线上用户实时更新,并且状态始终保持。它可以用于许多不同的目的,包括艺术、娱乐、设计和…...

qt-C++笔记之QStringList

qt-C笔记之QStringList —— 杭州 2023-12-03 文章目录 qt-C笔记之QStringList1.1.《Qt官方文档》第一部分翻译&#xff1a;继承自QList\<QString\>-初始化-添加字符串1.2.迭代字符串1.3.join()和split()1.4.filter()1.5.lastIndexOf()1.6.indexOf()1.7.replaceInString…...

ply前端

ply 是 eBPF 的 front-end 前端工具之一&#xff0c;专为 embedded Linux systems 开发&#xff0c;采用 C 语言编写&#xff0c;只需 libc 和内核支持 BPF 就可以运行&#xff0c;不需要外部 kernel 模块&#xff0c;不需要 LLVM&#xff0c;不需要 python。 ply 由瑞典工程师…...

U盘不仅能在电脑上使用,在手机上也可使用,包括安卓和苹果手机,但苹果的较特殊

许多最好的安卓手机都使用USB-C端口在电脑上充电和来回传输文件,但如果你需要给老板发电子邮件的文件放在闪存驱动器或全尺寸SD卡上呢? 幸运的是,使用廉价的适配器电缆,你可以将USB加密狗或读卡器直接连接到手机上。你甚至可以直接使用USB-C闪存驱动器,以实现更轻松的过程…...

抖音批量下载神器:免费一键收藏创作者全部作品

抖音批量下载神器&#xff1a;免费一键收藏创作者全部作品 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback support. 抖音…...

Pixel Language Portal快速部署:Hunyuan-MT-7B支持ONNX Runtime加速推理

Pixel Language Portal快速部署&#xff1a;Hunyuan-MT-7B支持ONNX Runtime加速推理 1. 项目概述 像素语言跨维传送门(Pixel Language Portal)是一款基于Tencent Hunyuan-MT-7B核心引擎构建的创新翻译工具。与传统翻译软件不同&#xff0c;它将语言转换过程重新设计为一场16-…...

PyTorch 2.8 实战案例:快速训练一个图像分类模型(附代码)

PyTorch 2.8 实战案例&#xff1a;快速训练一个图像分类模型&#xff08;附代码&#xff09; 1. 引言 图像分类是计算机视觉领域最基础也最实用的任务之一。无论是识别猫狗照片、检测医学影像&#xff0c;还是分析卫星图像&#xff0c;都需要可靠的分类模型作为基础。本文将带…...

胡桃工具箱:免费开源的原神桌面助手如何提升你的游戏体验

胡桃工具箱&#xff1a;免费开源的原神桌面助手如何提升你的游戏体验 【免费下载链接】Snap.Hutao 实用的开源多功能原神工具箱 &#x1f9f0; / Multifunctional Open-Source Genshin Impact Toolkit &#x1f9f0; 项目地址: https://gitcode.com/GitHub_Trending/sn/Snap.…...

单片机入门指南:硬件工程师成长路径与实战技巧

1. 单片机入门&#xff1a;从零开始的硬件工程师成长之路作为一名在嵌入式领域摸爬滚打多年的工程师&#xff0c;我见过太多初学者在单片机学习路上走弯路。单片机确实是个神奇的东西——它体积小、价格低&#xff0c;却能控制各种电子设备&#xff0c;从智能家居到工业自动化无…...

保姆级教程:在CompactLogix 5380上配置AB_Socket_TCP库,实现断线重连与自动收发

工业级TCP通信实战&#xff1a;CompactLogix 5380双IP配置与AB_Socket_TCP库深度应用 在工业自动化领域&#xff0c;稳定可靠的通信系统如同生产线的神经系统。当一台CompactLogix 5380控制器需要7x24小时不间断地与上位机、传感器网络或第三方设备交换数据时&#xff0c;传统的…...

PADS VX2.7实战指南:Router高效布线与等长设计技巧

1. PADS Router高效布线基础技巧 刚接触PADS Router时&#xff0c;最让我头疼的就是布线效率问题。后来发现&#xff0c;合理设置软件参数和掌握快捷键能极大提升工作效率。在PADS VX2.7中&#xff0c;Router工具的布线功能比Layout更加强大&#xff0c;特别适合处理复杂的高速…...

查看本地镜像使用 nrm 工具管理(方便切换)

1安装 nrm&#xff1a;npm install -g nrm2查看可用镜像源&#xff1a;nrm ls3切换到淘宝源nrm use taobao...

基于CasRel的微信小程序开发:智能合同关键信息抽取工具

基于CasRel的微信小程序开发&#xff1a;智能合同关键信息抽取工具 1. 引言 你有没有过这样的经历&#xff1f;面对一份几十页的合同&#xff0c;需要手动找出甲方、乙方、合同金额、签约日期、违约责任条款……一页页翻&#xff0c;一行行看&#xff0c;不仅耗时费力&#x…...

ai赋能开发:让快马平台智能生成mpu6050手势识别代码

最近在做一个基于MPU6050传感器的手势识别项目&#xff0c;发现用传统方式开发效率太低&#xff0c;于是尝试了InsCode(快马)平台的AI辅助开发功能。整个过程让我深刻体会到&#xff0c;AI如何改变硬件开发的效率瓶颈。 数据采集模块的智能生成 当我输入"用Arduino持续读取…...