雄县做网站/宁波品牌网站推广优化
Git 应用
一、Git概述
1.1 什么是Git
git 是一个代码协同管理工具,也称之为代码版本控制工具,代码版本控制或管理的工具用的最多的: svn、 git。
-
SVN
是采用的同步机制
,即本地的代码版本和服务器的版本保持一致(提交版本时,直接提交到服务器); -
Git
是采用异步机制
(分为本地仓库和远程仓库),本地提交的版本不会影响服务器的版本,只有本地的代码上传到服务器时才会同步。
git 是一个开源分布式版本控制系统,可用于高效的管理不同大小的项目, 05 年创造的,由林纳斯(Linux 之父)发明的。
1.2 git多人协同开发
代码版本管理工具主要的功能是 多人协同开发
,其 作用
是:
- 防止代码丢失,可以做备份;
- 代码版本的管理,可以进行多个版本之间的跳跃;
- 可以方便的将代码在多人之间进行共享传输;
- 多人开发时,有各种模式(分支、标签)可以方便代码管理。
1.3 git 的特点
- git 可以管理各种文件,特别是代码项目,多在 linux 和 unix 系统中使用
- 是分布式管理,不同于集中式,这是 git 和 svn 的核心区别
- git 可以很好的支持分支,方便多人协作工作 git 分布式代码分家安全,有全球唯一的
commit
版本号 - git 是开源的系统
- 使用 git 可以脱网工作(本地仓库),且数据传输速度较快
二、Git的安装与应用
2.1 Windows下Git的安装
下载地址:https://git-scm.com/downloads
一路next
2.2 Linux下安装
在Ubuntu系统下,基于apt安装
命令:
sudo apt-get install git -y
2.3 Git配置
三种配置级别
-
(1)
系统中所有的用户
都可以使用该配置,配置文件是:/etc/gitconfig
git config --system 配置信息
-
(2) 当前用户可使用该配置:配置文件是:
~/.gitconfig
git config --global 配置信息
-
(3) 当前项目可使用该配置,配置文件是:当前项目下的
./.git/config
git config
2.3.1 配置全局的用户名
给定git用户的名称(自定义)
git config --global user.name "zhb-git"
2.3.2 配置全局的用户邮箱
同配置用户名相同,自定义git用户的邮箱
git config --global user.email "1174333100@qq.com"
2.3.3 查看配置信息
配置信息后,可以查看配置信息,确认是都OK。
git config --list
#或
git config -l
2.4 Git常用指令
2.4.1 初始化本地仓库
在某个目录下,将当前目录作为本地仓库使用时。需要将此目录进行初始化:
git init
初始化命令执行成功后,会在当前目录下创建 .git
子目录。
2.4.2 添加文件到暂存区
将当前目录下的文件添加到暂存区中,
- 如果文件没有添加到暂存区时,显示的状态是红色的,
- 添加到暂存区之后,显示状态的颜色应该是绿色的。
查看文件的状态:
git status
添加文件到暂存区:
git add <文件或> ... | . | *
.
表示当前工作目录<文件>
表示具体的某一个文件全名(带后缀名)*
表示任意多个任意字符的文件,代表所有的文件及目录(目录中国的子文件及子目录)注意:添加到暂存区的文件没有存放在本地仓库中
可以将暂存区的文件删除:
git rm --cache <文件名> #删除暂存区的指定文件#或
git rm --cache -r . #递归删除所有文件(将暂存区的所有文件恢复到工作区)
注意:
git rm --cache -r .
命令可能会将仓库中的文件删除,如果出现这种情况,可以使用下面命令恢复:git restore --staged <file>...
git restore --staged <file>...
命令可以将暂存区文件还原
2.4.3 提交版本
将暂存区的文件,提交到本地仓库中,产生一个新的提交版本号(世界上唯一的)
git commit -m <提交说明> #将文件同步到本地仓库并且设置提示说明
注意:
- 一般提示时需要附加一些同步信息,在-m 后添加
- 所有对工作区的修改,如果想同步到仓库,都需要执行当前命令(add --> commit)
2.4.4 查看提交的版本信息
提交的版本 可以通过命令查看:
git log
可以限制显示版本号的数量:
git log -n 版本数量(具体的值: 1,2,3 等)
如果只想显示版本号和消息,可以单行显示:
git log --pretty=oneline
2.4.5 比较本地与仓库中的文件
在将文件提交到本地仓库之后,再次修改文件时,可以比较本地文件与仓库中的文件内容
比较:
git diff <file>
2.4.6 恢复操作
(1)、从本地仓库中恢复文件
git checkout <文件名>
aaa.txt 中的内容恢复到未修改之前的:
(2)、丢弃本地文件修改的内容
git checkout -- <文件名> #丢弃本地指定文件中的已经修改的内容( --两边都有空格)效果同上
(3)、本地仓库文件的移动和删除
无论移动还是删除,都会影响本地文件,修改后,必须再次提交版本 (再次执行 git commit)
git mv <源文件> <目的目录> #在本地仓库中将源文件移动目的目录中(本地也会移动)
删除:
git rm <文件名> # 在本地仓库中删除指定的文件(本地也会删除)
(4)、回到上一个版本
git reset --hard HEAD^ # HEAD 后面的^数量决定了回到上几个版本
(5)、回到指定的版本
git reset --hard <commit_id> #只需要 commit id 的唯一的前几位(至少4位)即可
(6)、查看所有的历史版本
git reflog #最新的操作始终在最上边
2.4.7 标签管理 (版本管理)
标签是在当前工作的位置添加的快照,用于保存工作状态,一般用于版本的迭代。
(1)、创建标签
在当前提交的版本上创建标签,如:
git tag 标签名 [-m "标签的消息"]
如果为指定提交版本号创建标签也可以的,如:
git tag <标签名称> <commit id> #指定某一个 commit id 处创建标签
(2)、查看标签
git tag
#或
git show <标签名称>
注意:如果出现了 : ,则需要按 q 退出。也可以在show命令上加参数 -q 。
(3)、删除标签
可以将标签(从版本号上)删除
git tag -d <标签名称>
(4)、恢复到指定标签
标签和版本号绑定的,在恢复代码版本时,可以使用标签
git reset --hard <标签名称>
2.4.8 临时工作区管理
临时工作区可以理解为某个区间,如:暂存区、当前工作区等。
(1)、创建临时工作区
目的:保存未提交文件的状态
- 红色【新文件、修改文件】未添加到暂存区的文件
- 绿色【已添加到暂存区的文件】
git stash
(2)、查看临时工作区
git stash list
注意:最近创建的临时工作区在列表的最上面,即 0号位置为最新创建的临时工作区。
(3)、使用指定工作区
git stash apply stash@{编号}
注意:在使用临时工作区时,当前工作区不能存在未提交的文件(暂存区必须是空的)
(4)、使用最新的临时工作区并删除(弹出)
git stash pop
(5)、删除指定的临时工作区
git stash drop stash@{编号}
(6)、删除所有的临时工作区
git stash clear
2.4.9 分支操作
分支主要用于多人协作工作,分支即获取原有代码,在此基础上创建自己的工作环境,单独开发,不会影响其他分支的操作,开发完成后再统一合并到主线分支中
创建分支的好处:安全,不影响其他人工作
(1)、分支的分类
按工程的项目进行代码分支的管理:以项目为准,存在master、develop
project(项目库)master(主线分支)hotfix(线上紧急 bug 修复分支)develop(开发分支)feature(功能分支)release(发布分支)bugfix(bug 修复分支)
(2)、查看当前分支
git branch

(3)、创建分支
I. 只创建分支
git branch <分支名称>
II. 创建并切换分支
git checkout -b <分支名称>
(4)、切换分支
git checkout <分支名称>
(5)、合并分支到当前分支
如果在当前分支下创建的新的分支存在新的提交的版本,则需要切换到当前分支下,可以将心的分支合并到当前分支。即父分支可以合并子分支。
如:
git merge <后代分支名称>
- 合并过程中如果没有冲突,直接合并后当前分支即为干净的状态,直接保存在本地仓库中
- 如果产生冲突,需要人为的选择,然后在进行 add 和 commit 的操作
- 在创建分支前,尽量保证当前分支是干净的,以减少冲突的发生
feature2
是develop分支的子分支, 子分支已提交了两个版本。
如果将feature2分支合并到develop分支上,则 需要先切换再合并。
(6)、删除分支
git branch -d < 分支名称>
(7)、衍合分支
git rebase <分支名>
效果同合并分支,但是不会创建新的版本号,只会更新父分支上最近提交的版本号(是在子分支创建之后提交的)
三、远程仓库
3.1 Gitee的远程仓库
远程仓库:中心服务器上的git仓库
- gitee:目前使用较多的是gitee(国内免费)
- github:国外免费,网速比较慢
- gitlab:私有仓库,企业内部搭建
gitee的网址:https://gitee.com/
需要注册账号,并登录。
3.2 配置gitee的ssh秘钥
gitee 支持http和ssh两个协议,http协议每次使用时,都需要手动输入用户名和口令,比较麻烦。
可以使用ssh协议,ssh协议支持公钥与私钥实现免密。
在gitbash的窗口中,生成公钥与私钥
命令如下
ssh-keygen
产看公钥:
cat ~/.ssh/id_rsa.pub
将此公钥粘贴在 gitee网页 —> 头像 下来菜单
选择 账号设置
菜单,在 设置页面,从 左边菜单
找到 SSH公钥
,点击之后,打开公钥设置界面,填写公钥名称和内容:
确认信息之后,点击【确定】
3.3 创建仓库
点击用户头像左边的 + 图标,在弹出的子菜单中选择 新建仓库 ,在打开页面,输入仓库的名称及介绍即可点击【创建】按钮。
3.4 本地仓库上传
3.4.1 首次上传
-
先将远程仓库的位置(ssh仓库位置)添加到本地仓库的配置中,
-
然后再上传,上 传时必须带
-u <远程仓库的名称> <分支名称>
git remote add origin git@gitee.com:disenQF/testgit2302.git
git push -u origin "master"
origin
是远程仓库的名称,可以自定义;
master
是远程仓库的分支名(默认的主分支名)。
3.4.2 再次上传
git push
3.4.3 强制上传
远程仓库的代码完全由本地仓库的代码替换
git push -u --force origin master
3.5 远程仓库下载
3.5.1 首次下载
通过
克隆
的方式下载的远程仓库
git clone git@gitee.com:用户名/仓库名
3.5.2 再次下载(更新)
git pull
相关文章:

00-Git 应用
Git 应用 一、Git概述 1.1 什么是Git git 是一个代码协同管理工具,也称之为代码版本控制工具,代码版本控制或管理的工具用的最多的: svn、 git。 SVN 是采用的 同步机制,即本地的代码版本和服务器的版本保持一致(提…...

安全运维是做什么的,主要工作内容是什么
安全运维,简称SecOps,是一种集成安全措施和流程到信息技术运维的实践。它的目的是确保在日常运维活动中,如网络管理、系统维护、软件更新等,均考虑并融入安全策略。安全运维的核心是实现安全和运维团队的密切协作,以快…...

nodejs+vue+ElementUi大学新生入学系统的设计与实现1hme0
采用B/S模式架构系统,开发简单,只需要连接网络即可登录本系统,不需要安装任何客户端。开发工具采用VSCode,前端采用VueElementUI,后端采用Node.js,数据库采用MySQL。 涉及的技术栈 1) 前台页面…...

Unity-序列化和反序列化
序列化是指把对象转换为字节序列的过程,而反序列化是指把字节序列恢复为对象的过程。序列化最主要的用途就是传递对象和保存对象。 在Unity中保存和加载、prefab、scene、Inspector窗口、实例化预制体等都使用了序列化与反序列化。 1 可序列化类型 1> 自定义的具有Serial…...

如何将语音版大模型AI接入自己的项目里(语音ChatGPT)
如何将语音版大模型AI接入自己的项目里语音ChatGPT 一、语音版大模型AI二、使用步骤1、接口2、请求参数3、请求参数示例4、接口 返回示例5、智能生成API代码 三、 如何获取appKey和uid1、申请appKey:2、获取appKey和uid 四、重要说明 一、语音版大模型AI 基于阿里通义千问、百…...

鸿蒙列表,item组件封装传参问题?@ObjectLink 和@Observerd
鸿蒙列表渲染,封装内容组件,进行item传参会报错? class FoodClass {order_id: number 0food_name: string ""food_price: number 0food_count: number 0 }Entry Component struct Demo07 {State message: string Hello World…...

信号与线性系统翻转课堂笔记12——时域取样定理
信号与线性系统翻转课堂笔记12 The Flipped Classroom12 of Signals and Linear Systems 对应教材:《信号与线性系统分析(第五版)》高等教育出版社,吴大正著 一、要点 (1)了解信号取样的概念࿱…...

爬虫工作量由小到大的思维转变---<Scrapy异常的存放小探讨>
前言: 异常很正常,调试异常/日志异常/错误异常~ 但在爬虫的时候,写完代码--->运行后根本挡不住一些运行异常;于是,把异常写到了中间件~ 当然,这也没有错; 不过,其实可以直接这么设计一下... 正文: 参照一下中间件处理的异常 def process_exception(self, request, exc…...

7.串口通信uart编写思路及自定义协议
前言: 串口是很重要的,有许多模块通信接口就是串口,例如gps模块,蓝牙模块,wifi模块还有一些精度比较高的陀螺仪模块等等,所以学会了串口之后,这些听起来很牛批的模块都能够用起来了。此外&#…...

【物联网】光影之谜:RGB-LED传感器引领科技变革之路
🌈个人主页:Sarapines Programmer🔥 系列专栏:《物联网实战 | 数字奇迹记》⏰翰墨致赠:狂风挟雷霆舞苍穹,剑气横扫万里空。英雄豪情铸不朽,激荡壮志燃热风。 目录 ⛳️1. 初识物联网 ⛳…...

promise的使用和实例方法
前言 异步,是任何编程都无法回避的话题。在promise出现之前,js中也有处理异步的方案,不过还没有专门的api能去处理链式的异步操作。所以,当大量的异步任务逐个执行,就变成了传说中的回调地狱。 function asyncFn(fn1, fn2, fn3) {setTimeout(() > {//处理第一个异步任务fn1…...

Visual Studio2022配置ReSharper C++ 常用设置
如需安装免费的可以在下面留言,看到即回复 文章目录 Visual Studio2022配置ReSharper C 常用设置配置Visual Studio2022,使其能够按回车进行补全配置ReSharper C 设置自动弹出配置ReSharper C 的快捷键ReSharper C 去掉注释拼写使用中文注释 如何关闭新版…...

论文解读类的公众号/知乎专栏,交给agent去做吧...
作者 | 二狗 大家好我是二狗,是夕小瑶科技说编辑部的一名作者。 我平时主要负责写AI资讯报道的文章。 大家知道,前阵子二狗我在「赛博马良」平台弄了个AI员工后每次都非常顺利地在第一时间精准抓到爆火的选题。 比如当时Sam Altman被开除的事件&…...

【学习笔记】Java函数式编程03 Stream流-终结操作
书接上回 3.3.3 终结操作 3.3.3.1 forEach 对集合的每一个元素进行处理 接触很多了不赘述 3.3.3.2 count 用来获取当前流中的元素的个数 比如,打印出所有作家的作品的总数 System.out.println(authors.stream().flatMap(author -> author.getBooks().stre…...

2024 Android保活总结
本文介绍的方案都是无需用户主动开启权限的。如果需要用户主动开启权限或者加白名单之类的话保活的意义就不大了,毕竟用户不大可能主动原因让app一直在后台运行 常规的方案 OnePixelActivity 1,监听SCREEN_OFF启动一个像素的Activity,灭屏…...

迅为RK3568开发板Ubuntu上使用串口调试
我们也可以在虚拟机的 Ubuntu 上使用调试串口。首先要参考 11 手册安装好 Ubuntu20.04。在 Ubuntu上可以安装多种串口工具,比如 minicom,picocom,kermit。本章节我们来介绍 minicom 的安装和使用。 输入以下命令安装 minicomapt-get install…...

【http】HTTP/1.0、HTTP/1.1和HTTP/2.0
✨ 专栏介绍 在当今互联网时代,计算机网络已经成为了人们生活和工作中不可或缺的一部分。而要实现计算机之间的通信和数据传输,就需要依靠各种网络协议来进行规范和约束。无论是浏览网页、发送电子邮件还是进行在线交流,都离不开各种各样的网…...

automkcert使用教程
我们在开发的时候往往需要https开启一些浏览器功能,比如摄像头、wss等,自己的云服务器申请证书一个是麻烦,一个是价格贵,这种情况下可以用自签名证书。但自签名证书下有不通用的特点,其他机器无法快速信任自己的网站,因…...

tekton 发布 kubernetes 应用
tekton 发布 kubernetes 应用 基于Kubernetes 服务部署 Tekton Pipeline 实例,部署完成后使用tekton来完成源码拉取、应用打包、镜像推送和应用部署。 本文实现一个 golang-helloworld 项目 CI/CD 的完整流程,具体包括以下步骤: 从 gitee…...

unity脚本API中OnCollisionEnter()、OnTriggerEnter()二者的区别
Unity中的OnCollisionEnter和OnTriggerEnter两个函数在日常的开发中很常见但也容易混淆,下面说一说两者的区别。 碰撞器(Collider)与触发器(Trigger)的概念 碰撞器(Collider)和触发器ÿ…...

2023年12月【考试战报】|ORACLE OCP 19C考试通过
2023年10月【考试战报】|ORACLE OCP 19C考试通过-CSDN博客文章浏览阅读122次。自OCP认证进入中国以来,越来越被大多数DBA所认可,也越来越被企业所重视,90%以上DBA深造,都会选择OCP认证。随着OCP认证在全国范围内的普及,…...

鸿蒙操作系统:从手机到物联网,打造全场景智能体验
随着科技的不断发展,人们对于操作系统的需求也在不断升级。鸿蒙操作系统,作为华为推出的新一代智能终端操作系统,凭借其强大的分布式能力、流畅的用户体验以及丰富的应用生态,正逐渐成为人们关注的焦点。 一、鸿蒙操作系统概述 …...

[Ray Tracing: The Next Week] 笔记
前言 本篇博客参照自《Ray Tracing: The Next Week》教程,地址为:https://raytracing.github.io/books/RayTracingTheNextWeek.html 该教程在ray tracing in one weekend的基础上,增加了运动模糊、BVH树、Texture映射、柏林噪声、光照、体积…...

企业级实战项目:基于 pycaret 自动化预测公司是否破产
本文系数据挖掘实战系列文章,我跟大家分享一个数据挖掘实战,与以往的数据实战不同的是,用自动机器学习方法完成模型构建与调优部分工作,深入理解由此带来的便利与效果。 1. Introduction 本文是一篇数据挖掘实战案例,…...

dl转置卷积
转置卷积 转置卷积,顾名思义,通过名字我们应该就能看出来,其作用和卷积相反,它可以使得图像的像素增多 上图的意思是,输入是22的图像,卷积核为22的矩阵,然后变换成3*3的矩阵 代码如下 import…...

详解结构体(包含结构体内存对齐,柔性数组,位段)【尊嘟很详细】
结构体 结构体是一些值的集合,这些值称为成员变量,结构的成员可以是标量、数组、指针,甚至是其他结构体。 成员名可以与程序中其它变量同名,互不干扰。 结构体的定义 (struct结构名{}) struct books {int a;c…...

我的NPI项目之Android系统升级 - 同平台多产品的OTA
因为公司业务中涉及的面比较广泛,虽然都是提供移动终端PDA,但是使用的场景很多时候是不同的。例如,有提供给大型物流仓储的设备,对这样的设备必需具备扫码功能,键盘(戴手套操作),耐用…...

pnpm包管理器
官网 优点 快速 pnpm 比 npm 快了近 2 倍高效 node_modules 中的所有文件均克隆或硬链接自单一存储位置支持单体仓库 pnpm 内置了对单个源码仓库中包含多个软件包的支持权限严格 pnpm 创建的 node_modules 默认并非扁平结构,因此代码无法对任意软件包进行访问 安…...

flutter websocket发送ping包?
背景 服务端要求flutter客户端隔一段时间发送ping包,以此来建立心跳管理长连接。 代码 import package:web_socket_channel/io.dart; IOWebSocketChannel _channel IOWebSocketChannel.connect(Uri.parse(SocketService.url),pingInterval: const Duration(seco…...

基于采样的自动驾驶规划算法 - PRM,RRT,RRT*,CL-RRT
本文将讲解PRM,RRT,RRT*自动驾驶规划算法原理,不正之处望读者指正 0 前言 机器人运动规划的基本任务:从开始位置到目标位置的运动 (1)如何躲避构型空间出现的障碍物 (2)如何满足机器…...