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

unity学习4:git和SVN的使用差别

目录

1 svn

1.1  操作逻辑

1.2 对应工具

1.3 SVN避免冲突的好习惯

2 git

2.1 git的基础操作逻辑

2.1.1 commit时,提交文件之外的其他文件需要pull

2.1.2 commit时,发现要提交的本地文件和服务器的文件冲突了

2.1.3 pull 时

2.2 对应工具

2.3 git的好习惯?

3 例子1:处理本地要提交的文件和服务器文件冲突

3.1 例子

3.2 错误方法:遇到冲突,直接丢弃的办法,不能彻底解决问题

3.3  如何解决git 的合并冲突 (正确方法)

4 git命令的学习

4.1 初始化 Git 仓库 git init

4.2 检查当前状态git status

4.3 添加更改到暂存区 git add .

4.4 提交更改 git commit

4.5  查看提交历史 git log

4.6 推送到远程仓库 git push

4.6.1 添加远程仓库

4.6.2 git push

4.7 获取最新更改 git pull

4.8 合并冲突

4.9 查看当前分支:git branch

4.10 创建新分支:git checkout -b <新分支名>

4.11 切换分支:git checkout <分支名>

4.12 删除本地分支:git branch -d <分支名>

4.13 克隆远程仓库:git clone <远程仓库地址>

5 阅读报错和处理


1 svn

1.1  操作逻辑

  • 1 不要求项目内所有文件全部相同
  • 2 只要求同1个文件,先取得最新版本后才能修改这个文件
  • 3 为了防止冲突,SVN还可以对每个文件加lock,避免出现2个人同时修改1个文件冲突的情况。

1.2 对应工具

  • 一般svn使用 tortoise

1.3 SVN避免冲突的好习惯

  • 文件先在SVN里加锁lock功能,需要设置
  • 先 更新要提交的文件
  • 然后使用前先解锁
  • 再进行 commit等操作

2 git

2.1 git的基础操作逻辑

2.1.1 commit时,提交文件之外的其他文件需要pull

针对1个分支,git要求整体更新,也就是进行操作前,必须和服务器上的分支版本全部一模一样了才能进行后面的操作

  • 提交前,必须保证除了你要修改得这个文件比服务器上的新,其他文件得全部相同。也就是所有项目工程内的文件都必须和服务器一样新,不能比服务器上旧。
  • 比如虽然之前已经pull了,但是在你操作的这个间隙,有其他人提交了一个其他文件的修改,你的本地就比服务器有一个文件旧了。
  • 否则就需要先把你这个要提交的新文件
  1. 先stash, 暂存到其他地方
  2. 然后pull,更新本地和服务器一样新
  3. 然后再 把stash的内容pop回来
  4. 再进行commit
  5. 再进行 push

(适用于文本文件,非二进制的文件)

  • 1先将本地修改存储起来
  • $ git stash
  • 这样本地的所有修改就都被暂时存储起来 。

  • 2 用git stash list可以看到保存的信息。
  • 其中stash@{0}就是刚才保存的标记。

  • 3暂存了本地修改之后,就可以pull了
  • $ git pull

  • 4 还原暂存的内容
  • $ git stash pop stash@{0}

2.1.2 commit时,发现要提交的本地文件和服务器的文件冲突了

需要进行冲突解决

step1: 选择要留下那个版本

  • 保留本地文件    git checkout --ours Data/configs.xlsx
  • 选择保留远程文件:git checkout --theirs Data/configs.xlsx  (一般选择这个)

step2  标记冲突已解决

  • 确认你已经选择了正确的文件后,添加文件到暂存区:
  • git add Data/configs.xlsx

step3: 完成合并

  • 提交解决后的更改:
  • git commit -m "Resolved merge conflict in Data/configs.xlsx"

step4: 同步代码

  • 最后,将代码推送到远程仓库:git push

2.1.3 pull 时

  • 如果你想进行拉取,git pull
  • 服务器上有内容比你本地新
  • if 你本地什么修改也没有,OK
  • if 你本地有其他比服务器新的内容,就会报错, 怎么处理呢?
  • 如果你本地有一些修改了,要么丢弃,要么先提交,总之得先保证和分支得服务器全部内容一模一样

  • 那如果我不pull,直接commit是不是就行了?
  • 也不行,这就是回到 2.1.1 会让你先stash ,再pull, 再提交

2.2 对应工具

  • 一般git使用 sourcetree
  • git也可以使用 tortoise
  • 还可以用 git bash

2.3 git的好习惯?

以下来自于百度AI

  • 如果 Data/configs.xlsx 经常发生冲突,可以考虑以下方法:
  • 避免多人编辑同一二进制文件。
  • 使用文件锁定机制(比如 Git LFS 提供的锁定功能)。
  • 将二进制文件存储在外部(如共享网盘或其他存储服务),而不是直接放在 Git 中。

3 例子1:处理本地要提交的文件和服务器文件冲突

3.1 例子

  • 别人修改了A文件,已经上传
  • 你也修改了A文件,准备上传。但是和服务器上的别人改的A文件内容不同。
  • 服务器的文件和本地要提交的文件冲突了

3.2 错误方法:遇到冲突,直接丢弃的办法,不能彻底解决问题

  • 比如,遇到冲突
  • git merge --abort
  • git reset  --merge
  • git status             
  • git status  可以查看现在的这个分支的的状态,是否有提交冲突等
  • 前说有冲突,我把我本地放弃了,也能pull了。但是还是说有警告:因为冲突需要解决,不能删了了事,等你git pull的时候,还会报错

3.3  如何解决git 的合并冲突 (正确方法)

  • 你的问题是合并冲突,特别是二进制文件 Data/configs.xlsx 出现冲突,Git 无法自动合并。
  • 二进制文件(比如 Excel 文件)无法像文本文件一样进行合并,需要手动解决冲突。
  • 以下是解决方法:

step1: 使用 git status 查看冲突的文件时哪些,git diff 看冲突的具体内容

  • 检查冲突:运行 git status 查看哪些文件处于冲突状态。
  • 查看冲突详情:使用 git diff 查看具体的冲突内容。

step2: 选择要留下那个版本

  • 保留本地文件    git checkout --ours Data/configs.xlsx
  • 选择保留远程文件:git checkout --theirs Data/configs.xlsx  (一般选择这个)

step3  标记冲突已解决

  • 标记冲突为已解决:对于每个已解决的冲突文件,运行 git add <文件名> 将其标记为已解决。
  • 确认你已经选择了正确的文件后,添加文件到暂存区:
  • git add Data/configs.xlsx

step4: 完成合并

  • 提交解决后的更改:
  • git commit -m "Resolved merge conflict in Data/configs.xlsx"

step5: 同步代码

  • 最后,将代码推送到远程仓库:git push

伪代码流程:

git status # 查看冲突文件

git diff --name-only --diff-filter=U | xargs code & # 使用code编辑器打开所有未解决的冲突文件

# 手动解决冲突...

git add . # 添加所有解决后的文件

git commit # 提交更改

4 git命令的学习

4.1 初始化 Git 仓库 git init

  • 如果你的项目尚未初始化为 Git 仓库,可以使用以下命令:
  • 此命令将在当前目录创建一个新的 Git 仓库。

4.2 检查当前状态git status

  • 在任何操作前,建议检查当前工作区和暂存区的状态:
  • 此命令会显示哪些文件已更改、哪些文件未被跟踪,以及哪些文件已准备提交。

4.3 添加更改到暂存区 git add .

  • 添加单个文件:         git add <文件名>
  • 添加所有更改的文件:git add . 
  • 提示:git add . 会将当前目录及其子目录中所有更改过或新增的文件添加到暂存区。

4.4 提交更改 git commit

  • 使用以下命令提交已暂存的更改到本地仓库:
  • git commit -m "<提交信息>"
  • -m: 提交时添加的简短描述。
  • 提交信息应简洁明了,通常描述本次更改的内容


4.5  查看提交历史 git log

  • 使用以下命令查看仓库的提交记录:git log
  • 如果想简化显示,可以使用:git log --oneline


4.6 推送到远程仓库 git push


4.6.1 添加远程仓库

  • 如果尚未设置远程仓库,可以使用以下命令:git remote add origin <远程仓库地址>
  • 例如:git remote add origin https://github.com/username/repository.git
  • 推送更改

4.6.2 git push

  • 将本地提交推送到远程仓库:git push origin <分支名>
  • 例如,推送到主分支:git push origin main


4.7 获取最新更改 git pull

  • 在多人协作的情况下,先拉取远程仓库的最新更改:
  • git pull origin <分支名>
  • git pull实质上是git fetchgit merge FETCH_HEAD的组合,它会获取(fetch)远程仓库中所有分支的更新并与你的本地分支进行合并(merge)。


4.8 合并冲突

  • 如果在拉取或合并代码时发生冲突,Git 会提示需要手动解决冲突。步骤如下:
  • 编辑冲突文件,解决冲突标记(<<<<<<<, =======, >>>>>>>)。
  • 将解决后的文件添加到暂存区:git add <冲突文件>
  • 提交解决冲突后的代码:git commit -m "Resolve merge conflict"


4.9 查看当前分支:git branch


4.10 创建新分支:git checkout -b <新分支名>

4.11 切换分支:git checkout <分支名>

4.12 删除本地分支:git branch -d <分支名>

4.13 克隆远程仓库:git clone <远程仓库地址>

5 阅读报错和处理(待完善)

https://zhuanlan.zhihu.com/p/40452986icon-default.png?t=O83Ahttps://zhuanlan.zhihu.com/p/40452986

相关文章:

unity学习4:git和SVN的使用差别

目录 1 svn 1.1 操作逻辑 1.2 对应工具 1.3 SVN避免冲突的好习惯 2 git 2.1 git的基础操作逻辑 2.1.1 commit时&#xff0c;提交文件之外的其他文件需要pull 2.1.2 commit时&#xff0c;发现要提交的本地文件和服务器的文件冲突了 2.1.3 pull 时 2.2 对应工具 2.3 …...

四大自平衡树对比:AVL树、红黑树、B树与B+树

AVL树、红黑树、B树和B树的对比与应用场景 树系列相关文章&#xff08;置顶&#xff09; 1、从链表到平衡树&#xff1a;二叉查找树的退化与优化 2、自平衡二叉查找树&#xff1a;如何让二叉查找树始终保持高效 3、AVL树入门&#xff1a;理解自平衡二叉查找树的基础 4、红黑树全…...

BUUCTF Pwn ciscn_2019_es_2 WP

1.下载 checksec 用IDA32打开 定位main函数 发现了个假的后门函数&#xff1a; 看看vul函数&#xff1a; 使用read读取 想到栈溢出 但是只有48个 只能覆盖EBP和返回地址 长度不够构造 所以使用栈迁移&#xff1a; 栈迁移需要用到leave ret 使用ROPgadget找地址&#xff1a; …...

MongoDb-mongosh-登录

本地登录 mongosh --username root --password xxx 参考&#xff1a;Connect to a Deployment - MongoDB Shell...

C语言day3:shell脚本

一、作业题3 使用数组求出当前目录下.sh文件的个数 二、作业题4 使用数组求家目录下文件的个数 三、思维导图...

微信小程序Uniapp

使用命令行创建项目&#xff08;vuets&#xff09; npx degit dcloudio/uni-preset-vue#vite-ts my-vue3-project然后用HBX打开项目 再安装依赖 npm i 再运行开发版本&#xff0c;生成dist目录 pnpm dev:mp-weixin 注意要设置APPid 再用微信小程序打开...

mongoTemplate的复杂组装条件查询

mongoTemplate不像SQL那么灵活&#xff0c;组装条件较为复杂。 如下演示了查询类似于 AND name ‘张三’ OR age 12 NOT birthday > 2024-12-31 这类结构的代码示例。 脑子里的范围图&#xff1a; 所有的AND锁定一个范围&#xff0c;再跟所有的OR组成的范围取并集&#…...

httpslocalhostindex 配置的nginx,一刷新就报404了

当你的Nginx配置导致页面刷新时报404错误时&#xff0c;通常是由于以下几个原因造成的&#xff1a; 静态文件路径配置错误&#xff1a;Nginx没有正确地指向静态文件的目录。前端路由问题&#xff1a;如果是SPA&#xff08;单页应用&#xff09;&#xff0c;刷新页面时Nginx没有…...

pandas删除值全部为0的整行和整列,还有0.0,0.000000也要删除

在 Pandas 中&#xff0c;如果需要删除全部为 0 的行或列&#xff0c;可以通过 .all() 方法来判断行或列是否所有元素都为 0&#xff0c;然后删除这些行或列。 代码示例 示例数据&#xff1a; import pandas as pd# 示例数据 data {A: [0, 2, 0, 4],B: [0, 0, 0, 0],C: [0, …...

IO Virtualization with Virtio.part 1 [十二]

久等了各位&#xff01; 本篇开始讲解 IO 虚拟化中的 virtio&#xff0c;我会以 Linux 的 IIC 驱动为例&#xff0c;从 IIC 驱动的非虚拟化实现&#xff0c;到 IIC 驱动的半虚拟化实现&#xff0c;再到最后 X-Hyper 中如何通过 virtio 来实现前后端联系&#xff0c;一步步把 v…...

ShardingSphere-Proxy分表场景:go测试案例

接续上篇文章《ShardingSphere-Proxy分表场景测试案例》 go测试用例&#xff1a; package mainimport ("fmt""math/rand""time""github.com/bwmarrin/snowflake""gorm.io/driver/mysql""gorm.io/gorm""gor…...

OpenStack系列第四篇:云平台基础功能与操作(Dashboard)

文章目录 1. 镜像&#xff08;Image&#xff09;添加镜像查看镜像删除镜像 2. 卷&#xff08;Volume&#xff09;创建卷查看卷删除卷 3. 网络&#xff08;虚拟网络&#xff09;创建网络查看网络删除网络 4. 实例类型创建实例类型查看实例类型删除实例类型 4. 密钥对&#xff08…...

ESP32 I2S音频总线学习笔记(一):初识I2S通信与配置基础

文章目录 简介为什么需要I2S&#xff1f;关于音频信号采样率分辨率音频声道 怎样使用I2S传输音频&#xff1f;位时钟BCLK字时钟WS串行数据SD I2S传输模型I2S通信格式I2S格式左对齐格式右对齐格式 i2s基本配置i2s 底层API加载I2S驱动设置I2S使用的引脚I2S读取数据I2S发送数据卸载…...

25上半年软考高级系统分析师易混淆知识点

第1章 系统工程与信息系统基础 易混淆点1&#xff1a;系统工程生命周期与信息系统的生命周期 1、系统工程生命周期阶段 探索性研究→概念阶段→开发阶段→生产阶段→使用阶段→保障阶段→退役阶段 2、信息系统的生命周期 产生阶段→开发阶段&#xff08;单个系统开发&…...

采集JSON解析错误的修复

两段采集来的JSON格式&#xff1a; 一&#xff1a; {"hwgOnlineId":"554312", "jiwuChatId":"", "phoneCategoryId":"20006", "cuxiaoSeq":{voucherTitle:1,lh 二&#xff1a; {"pic":&q…...

Java中实现对象的深拷贝(Deep Copy)

在Java中实现对象的深拷贝&#xff08;Deep Copy&#xff09;意味着创建一个对象的副本&#xff0c;使得原对象和副本对象完全分离&#xff0c;对副本对象的任何修改都不会影响到原对象。以下是几种实现深拷贝的方法&#xff1a; 1. 手动实现深拷贝 对于自定义类&#xff0c;…...

位置编码-APE

Transformer 中的绝对位置编码 &#xff08;以下由gpt 生成&#xff09; Transformer 的绝对位置编码&#xff08;Absolute Position Encoding, APE&#xff09;是用于对序列数据中的位置信息进行建模的一种方法。在 Transformer 的架构中&#xff0c;输入数据&#xff08;如句…...

MySQL有哪些锁?

1.MySQL有哪些锁&#xff1f; 全局锁表级锁 表锁元数据锁意向锁 行级锁 记录锁间隙锁临键锁临时意向锁 我了解的是MySQL的锁可以分为全局锁、表级锁、行级锁。 我比较熟悉的是表级锁和行级锁&#xff0c;如果我们对表结构进行修改时&#xff0c;MySQL就会对这个表结构加一个…...

Everything实现,快速搜索文件

最近编写NTFS文件实时搜索工具, 类似 Everything 这样, 翻阅了很多博客, 结果大致如下: 1.分析比较肤浅, 采用USN日志枚举来获取文件记录 速度一言难尽, 因为日志枚举的是全盘所有文件的所有日志, 记录比文件记录还多, 速度当然很慢, 还有的甚至于是 使用 DeviceIoControl 函数…...

[硬件] DELL BIOS 相关注意事项

前言 前段时间重装系统. DELL BIOS属实资料少, 又难用. 这里给出相关的注意事项, 并且配上图片. BIOS相关注意事项 进入BIOS ESC/F2/ F12. 都可以进入BIOS, 当进U盘的入Win PE系统时, 使用F12 效果更佳. 关闭安全模式 切换到Boot Configuration选项,将Secure Boot选项off选…...

DockerHub与私有镜像仓库在容器化中的应用与管理

哈喽&#xff0c;大家好&#xff0c;我是左手python&#xff01; Docker Hub的应用与管理 Docker Hub的基本概念与使用方法 Docker Hub是Docker官方提供的一个公共镜像仓库&#xff0c;用户可以在其中找到各种操作系统、软件和应用的镜像。开发者可以通过Docker Hub轻松获取所…...

mongodb源码分析session执行handleRequest命令find过程

mongo/transport/service_state_machine.cpp已经分析startSession创建ASIOSession过程&#xff0c;并且验证connection是否超过限制ASIOSession和connection是循环接受客户端命令&#xff0c;把数据流转换成Message&#xff0c;状态转变流程是&#xff1a;State::Created 》 St…...

大语言模型如何处理长文本?常用文本分割技术详解

为什么需要文本分割? 引言:为什么需要文本分割?一、基础文本分割方法1. 按段落分割(Paragraph Splitting)2. 按句子分割(Sentence Splitting)二、高级文本分割策略3. 重叠分割(Sliding Window)4. 递归分割(Recursive Splitting)三、生产级工具推荐5. 使用LangChain的…...

MODBUS TCP转CANopen 技术赋能高效协同作业

在现代工业自动化领域&#xff0c;MODBUS TCP和CANopen两种通讯协议因其稳定性和高效性被广泛应用于各种设备和系统中。而随着科技的不断进步&#xff0c;这两种通讯协议也正在被逐步融合&#xff0c;形成了一种新型的通讯方式——开疆智能MODBUS TCP转CANopen网关KJ-TCPC-CANP…...

高危文件识别的常用算法:原理、应用与企业场景

高危文件识别的常用算法&#xff1a;原理、应用与企业场景 高危文件识别旨在检测可能导致安全威胁的文件&#xff0c;如包含恶意代码、敏感数据或欺诈内容的文档&#xff0c;在企业协同办公环境中&#xff08;如Teams、Google Workspace&#xff09;尤为重要。结合大模型技术&…...

从零开始打造 OpenSTLinux 6.6 Yocto 系统(基于STM32CubeMX)(九)

设备树移植 和uboot设备树修改的内容同步到kernel将设备树stm32mp157d-stm32mp157daa1-mx.dts复制到内核源码目录下 源码修改及编译 修改arch/arm/boot/dts/st/Makefile&#xff0c;新增设备树编译 stm32mp157f-ev1-m4-examples.dtb \stm32mp157d-stm32mp157daa1-mx.dtb修改…...

【配置 YOLOX 用于按目录分类的图片数据集】

现在的图标点选越来越多&#xff0c;如何一步解决&#xff0c;采用 YOLOX 目标检测模式则可以轻松解决 要在 YOLOX 中使用按目录分类的图片数据集&#xff08;每个目录代表一个类别&#xff0c;目录下是该类别的所有图片&#xff09;&#xff0c;你需要进行以下配置步骤&#x…...

HashMap中的put方法执行流程(流程图)

1 put操作整体流程 HashMap 的 put 操作是其最核心的功能之一。在 JDK 1.8 及以后版本中&#xff0c;其主要逻辑封装在 putVal 这个内部方法中。整个过程大致如下&#xff1a; 初始判断与哈希计算&#xff1a; 首先&#xff0c;putVal 方法会检查当前的 table&#xff08;也就…...

论文笔记——相干体技术在裂缝预测中的应用研究

目录 相关地震知识补充地震数据的认识地震几何属性 相干体算法定义基本原理第一代相干体技术&#xff1a;基于互相关的相干体技术&#xff08;Correlation&#xff09;第二代相干体技术&#xff1a;基于相似的相干体技术&#xff08;Semblance&#xff09;基于多道相似的相干体…...

排序算法总结(C++)

目录 一、稳定性二、排序算法选择、冒泡、插入排序归并排序随机快速排序堆排序基数排序计数排序 三、总结 一、稳定性 排序算法的稳定性是指&#xff1a;同样大小的样本 **&#xff08;同样大小的数据&#xff09;**在排序之后不会改变原始的相对次序。 稳定性对基础类型对象…...