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

news2025/3/9 22:32:42

目录

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2271179.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【数据库初阶】MySQL数据类型

&#x1f389;博主首页&#xff1a; 有趣的中国人 &#x1f389;专栏首页&#xff1a; 数据库初阶 &#x1f389;其它专栏&#xff1a; C初阶 | C进阶 | 初阶数据结构 亲爱的小伙伴们&#xff0c;大家好&#xff01;在这篇文章中&#xff0c;我们将深入浅出地为大家讲解 MySQL…

kubernetes学习-Service

kubernetes学习-Service 1. Service说明2. 功能3.Service类型3.1 NodePort3.1.1 创建web-service.yaml3.1.2 创建web-pod.yaml3.1.3 部署3.1.4 验证 3.2 ClusterIP3.2.1 创建web-clusterIp-service.yaml3.2.2 创建web-clusterIp-pod.yaml3.2.3 部署3.2.4 验证 3.3 LoadBalancer…

滤波器的主要参数

为什么选择高阶&#xff1a; 滤波器的主要参数通常包括以下几个方面&#xff1a; 截止频率 (Cutoff Frequency)&#xff1a; 这是滤波器能够有效通过或抑制信号的频率点。对于低通滤波器&#xff0c;信号低于截止频率的部分会被通过&#xff0c;高于截止频率的部分会被衰减。高…

设计模式 创建型 单例模式(Singleton Pattern)与 常见技术框架应用 解析

单例模式&#xff08;Singleton Pattern&#xff09;是一种创建型设计模式&#xff0c;旨在确保某个类在应用程序的生命周期内只有一个实例&#xff0c;并提供一个全局访问点来获取该实例。这种设计模式在需要控制资源访问、避免频繁创建和销毁对象的场景中尤为有用。 一、核心…

290-3U VPX i7 刀片计算机

一、产品概述 该产品是一款基于第三代Intel i7双核四线程的高性能3U VPX刀片式计算机。产品提供了多个高速PCIe总线接口&#xff0c;其中3个x4 PCIe 3.0接口&#xff0c;1个x4 PCIe 2.0接口。x4 PCIe 2.0接口可灵活配置为4个x1 PCIe接口&#xff0c;因此产品具有很强的扩展性&a…

【从零开始入门unity游戏开发之——C#篇41】C#迭代器(Iterator)——自定义类实现 foreach 操作

文章目录 前言一、什么是迭代器&#xff1f;二、标准迭代器的实现方法1、自定义一个类CustomList2、让CustomList继承IEnumerable接口3、再继承IEnumerator接口4、完善迭代器功能5、**foreach遍历的本质**&#xff1a;6、在Reset方法里把光标复原 三、用yield return语法糖实现…

win32汇编环境,对话框程序中通过资源显示bmp图像

;运行效果 ;win32汇编环境,对话框程序中通过资源显示bmp图像 ;通过资源的方式&#xff0c;会把图像固定在exe文件里&#xff0c;会变大。通过读取文件的方式&#xff0c;没有固定在exe文件里&#xff0c;也可以随时换图像文件&#xff0c;所以exe文件较小 ;直接抄进RadAsm可编译…

MATLAB画柱状图

一、代码 clear; clc; figure(position,[150,100,900,550])%确定图片的位置和大小&#xff0c;[x y width height] %准备数据 Y1[0.53,7.9,8.3;0.52,6.8,9.2;0.52,5.9,8.6;2.8,5.8,7.9;3.9,5.2,7.8;1.8,5.8,8.4]; % withoutNHC X11:6; %画出4组柱状图&#xff0c;宽度1 h1…

java 搭建一个springboot3.4.1项目 JDK21

环境准备 idea:2021 springboot:3.4.1 JDK:21 maven:3.6.3 新建项目 点击new->project->spring initializr 选择springboot版本 1.选择springboot版本&#xff0c;因为JDK版本是21因此对应springboot3.X Spring Boot 2.6.x&#xff1a;适用于JDK 8到17&#xff0c…

第R3周:RNN-心脏病预测

&#x1f368; 本文为&#x1f517;365天深度学习训练营 中的学习记录博客&#x1f356; 原作者&#xff1a;K同学啊 文章目录 一、前言二、代码流程1、导入包&#xff0c;设置GPU2、导入数据3、数据处理4、构建RNN模型5、编译模型6、模型训练7、模型评估 电脑环境&#xff1a;…

40% 降本:多点 DMALL x StarRocks 的湖仓升级实战

小编导读&#xff1a; 多点 DMALL 成立于2015年&#xff0c;持续深耕零售业&#xff0c;为企业提供一站式全渠道数字零售解决方案 DMALL OS。作为 DMALL OS 数字化能力的技术底座&#xff0c;大数据平台历经多次迭代平稳支撑了公司 To B 业务的快速开展。随着国家产业升级和云原…

Docker 环境中搭建 Redis 哨兵模式集群的步骤与问题解决

在 Docker 环境中搭建 Redis 哨兵模式集群的步骤与问题解决 在 Redis 高可用架构中&#xff0c;哨兵模式&#xff08;Sentinel&#xff09;是确保 Redis 集群在出现故障时自动切换主节点的一种机制。通过使用 Redis 哨兵&#xff0c;我们可以实现 Redis 集群的监控、故障检测和…

华为消费级QLC SSD来了

近日&#xff0c;有关消息显示&#xff0c;华为的消费级SSD产品线&#xff0c;eKitStor Xtreme 200E系列&#xff0c;在韩国一家在线零售商处首次公开销售&#xff0c;引起了业界的广泛关注。 尽管华为已经涉足服务器级别的SSD制造多年&#xff0c;但直到今年6月才正式推出面向…

StableDiffusionWebUI本地部署指南(WIN)

最近接手了一个需要使用 Stable Diffusion 的项目&#xff0c;要重新部署一套 SD 环境。这跟我之前的SD部署又不太一样&#xff0c;部署过程中遇到一些问题&#xff0c;总结出一个比较完美的安装方案&#xff0c;在这里和大家分享一下。 项目地址&#xff1a;https://github.c…

运动控制探针功能详细介绍(CODESYS+SV63N伺服)

汇川AM400PLC和禾川X3E伺服EtherCAT通信 汇川AM400PLC和禾川X3E伺服EtherCAT通信_汇川ethercat通信-CSDN博客文章浏览阅读1.2k次。本文详细介绍了如何使用汇川AM400PLC通过EtherCAT总线与禾川X3E伺服进行通信。包括XML硬件描述文件的下载与安装,EtherCAT总线的启用,从站添加…

ELK日志平台搭建 (最新版)

一、安装 JDK 1. 下载 JDK 21 RPM 包 wget https://download.oracle.com/java/21/latest/jdk-21_linux-x64_bin.rpm2. 安装 JDK 21,使用 rpm 命令安装下载的 RPM 包&#xff1a; sudo rpm -ivh jdk-21_linux-x64_bin.rpm3. 配置环境变量 编辑 /etc/profile 文件以配置 JAVA_HO…

pygame飞机大战

飞机大战 1.main类2.配置类3.游戏主类4.游戏资源类5.资源下载6.游戏效果 1.main类 启动游戏。 from MainWindow import MainWindow if __name__ __main__:appMainWindow()app.run()2.配置类 该类主要存放游戏的各种设置参数。 #窗口尺寸 import random import pygame WIND…

应用架构模式

设计模式 设计模式是指根据通用需求来设计解决方案的模板或蓝图&#xff0c;使用设计模式能够更加有效地解决设计过程中的常见问题。设计模式针对不同的问题域有不同的内涵&#xff0c;主要涉及业务、架构、程序设计等问题域&#xff0c;本文主要讨论架构设计模式。 业务设计模…

el-input输入框需要支持多输入,最后传输给后台的字段值以逗号分割

需求&#xff1a;一个输入框字段需要支持多次输入&#xff0c;最后传输给后台的字段值以逗号分割 解决方案&#xff1a;结合了el-tag组件的动态编辑标签 那块的代码 //子组件 <template><div class"input-multiple-box" idinputMultipleBox><div>…

【新教程】华为昇腾NPU的pytorch环境搭建

1 硬件配置 使用学校的集群&#xff0c;相关配置如下&#xff1a; CPU&#xff1a;鲲鹏920 NPU&#xff1a;昇腾910B 操作系统&#xff1a;openEuler 22.03 2 安装版本 根据昇腾官方gitee上的信息&#xff0c;Pytoch 2.1.0是长期支持版本&#xff0c;因此选择安装这一版本&a…