git 操作

本文介绍了如何在Git中去除多余的合并日志,设置拉取时自动重基。当遇到分离HEAD状态时,提供了创建新分支、切换分支、合并改动以及使用gitreset--hard和--soft命令的解决方案。此外,还提到了如何修改默认编辑器为vim。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 git 去掉多余的“Merging 日志

 git config --global pull.rebase true

新增分支无法Pull到的操作方法

git remote -v  查看远程仓库地址

git remote rm origin   ----- 删除远端仓库地址

git remote add  -----添加远端仓库地址

git--“HEAD detached from”解决方法

报错解释:
当你在Git中检出一个特定的提交(commit),但不是在任何分支的最新提交上时,Git会处于“分离HEAD”状态。这意味着你当前的工作状态不是基于任何分支的最新提交,而是独立的。

解决方法:

  1. 如果你想要基于这个独立的HEAD状态继续工作,并最终创建一个新的提交,你可以直接在当前HEAD的基础上进行修改,并提交。
  2. 如果你想要回到一个分支的最新提交,可以创建一个新的分支,或者切换到已有的分支:

      git checkout -b new-branch-name--------创建一个新的分支

      git checkout existing-branch-name-------切换到已有分支

3. 如果你想要将分离HEAD的改动合并到已有分支,可以先切换到目标分支,然后合并:

git checkout existing-branch-name
git merge HEAD

4,如果你不需要当前的分离HEAD状态下的改动,可以重置HEAD到一个分支的最新提交:

git reset --hard existing-branch-name

git reset --hard 和--soft

当你执行git reset --hard命令时,会重置当前分支的HEAD和索引(index)到指定的提交(commit),同时丢弃工作目录中的所有改动。这意味着你会丢失所有未提交的更改,并且无法恢复。

当你执行git reset --soft命令时,会重置当前分支的HEAD和索引(index)到指定的提交(commit),但是会保留工作目录中的所有更改。这意味着你可以重新提交这些工改,或者将它们保存为新的提交。

总结起来,git reset --hard是一种彻底重置的方式,会丢所有更改;而git reset --soft是一种保留更改的方式,使用于需要撤销一次提交并重新提交的场景。

修改编辑器

git config --global core.editor vim

git submodule

git submodule --update --init --recursive


用于在 Git 子模块中初始化和更新子模块。让我们解释一下命令的各个部分:

git submodule:这是用于处理 Git 子模块的主要 Git 命令。
–update 或 -u:此选项检查超级项目中记录的提交。它还将子模块的工作目录更新为超级项目中指定的提交。
–init 或 -i:此选项初始化在存储库配置中定义但尚未初始化的所有子模块。
–recursive 或 -r:此选项递归地初始化和更新所有子模块。如果子模块本身包含子模块,它们也将被初始化和更新。
因此,当运行命令 git submodule --update --init --recursive 时,您确保:

子模块已被初始化(如果尚未初始化)。
子模块已更新到超级项目中指定的提交。
如果子模块本身包含子模块,它们也将被递归地初始化和更新。

在Git中,子模块(submodule)是指一个Git仓库内包含另一个Git仓库。这种情况通常发生在项目需要使用其他项目(通常是第三方库或外部组件)的代码,但是你不想将这些代码直接合并到主项目中,而是希望以子模块的形式进行管理。

使用子模块有助于保持项目的组织结构清晰,并使得在不同项目之间共享和维护代码变得更容易。子模块允许你在主项目中引用其他项目,并在需要时检出或更新这些项目的特定版本。这有助于确保每个项目都使用与其它项目协作所需的特定版本。

当你将一个Git仓库作为子模块添加到另一个Git仓库时,父仓库会记录子仓库的位置和特定的提交(版本)。然后,你可以使用git submodule命令来初始化、更新和管理这些子模块。

总之,子模块是一种Git中组织代码的方式,允许你在一个项目中包含另一个项目的特定版本。

git submodule update --remote

更新子模块命令。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

李小白20200202

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值