经验笔记:git checkout 与 git switch

Git Checkout 与 Git Switch

引言

在使用 Git 进行版本控制时,git checkoutgit switch 是两个常用的命令,用于分支管理和文件恢复。虽然它们有一些相似之处,但各自的功能和使用场景有所不同。本文将详细介绍这两个命令的用法、区别和实际应用示例,帮助你更好地理解和使用它们。

git checkout

基本用法

  1. 切换分支

    sh 复制代码
    git checkout <branch>

    例如,切换到 main 分支:

    sh 复制代码
    git checkout main
  2. 创建并切换到新分支

    sh 复制代码
    git checkout -b <new-branch>

    例如,创建并切换到 feature-branch

    sh 复制代码
    git checkout -b feature-branch
  3. 恢复工作区中的文件

    sh 复制代码
    git checkout -- <file>

    例如,恢复 file.txt 到最近一次提交的状态:

    sh 复制代码
    git checkout -- file.txt
  4. 切换到某个特定的提交

    sh 复制代码
    git checkout <commit_hash>

    例如,切换到某个特定的提交 abc1234

    sh 复制代码
    git checkout abc1234

    这将使你的工作区处于"分离头指针"(detached HEAD)状态。

高级用法

  1. 创建新分支并切换到特定的提交

    sh 复制代码
    git checkout -b <new-branch> <commit_hash>

    例如,从提交 abc1234 创建并切换到 feature-branch

    sh 复制代码
    git checkout -b feature-branch abc1234
  2. 恢复文件到特定的提交

    sh 复制代码
    git checkout <commit_hash> -- <file>

    例如,恢复 file.txt 到提交 abc1234 的状态:

    sh 复制代码
    git checkout abc1234 -- file.txt
  3. 查看某个提交的文件内容

    sh 复制代码
    git checkout <commit_hash> -- <file> | cat

    例如,查看提交 abc1234file.txt 的内容:

    sh 复制代码
    git checkout abc1234 -- file.txt | cat

git switch

基本用法

  1. 切换分支

    sh 复制代码
    git switch <branch>

    例如,切换到 main 分支:

    sh 复制代码
    git switch main
  2. 创建并切换到新分支

    sh 复制代码
    git switch -c <new-branch>

    例如,创建并切换到 feature-branch

    sh 复制代码
    git switch -c feature-branch
  3. 切换到远程分支

    sh 复制代码
    git switch <remote>/<branch>

    例如,切换到远程仓库 originmain 分支:

    sh 复制代码
    git switch origin/main

高级用法

  1. 创建并切换到新分支,从某个起点开始

    sh 复制代码
    git switch -c <new-branch> <start-point>

    例如,从 main 分支创建并切换到 feature-branch

    sh 复制代码
    git switch -c feature-branch main
  2. 强制切换分支并丢弃未提交的更改

    sh 复制代码
    git switch --discard-changes <branch>

    例如,强制切换到 main 分支并丢弃未提交的更改:

    sh 复制代码
    git switch --discard-changes main

功能对比

  • git checkout

    • 多用途命令,可以切换分支、恢复文件、切换到特定提交等。
    • 功能丰富,但命令复杂,容易混淆。
    • 适用于需要多种操作的场景。
  • git switch

    • 专门用于分支切换的命令。
    • 功能单一,命令简单,易于记忆和使用。
    • 适用于只需要切换分支的场景。

场景选择

  • 初学者 :建议使用 git switch,因为它功能明确,命令简单,不容易出错。
  • 高级用户 :可以根据具体需求选择合适的命令。如果你需要恢复文件或切换到特定提交,使用 git checkout;如果只需要切换分支,使用 git switch

希望这篇经验笔记对你有帮助!

相关推荐
CSDN_PBB4 小时前
[STM32 - 野火] - - - 固件库学习笔记 - - - 十五.设置FLASH的读写保护及解除
笔记·stm32·学习
夜流冰8 小时前
编程参考 - C语言可变参数
笔记
格雷亚赛克斯9 小时前
Qt笔记31-69
数据库·笔记·qt
Long_poem9 小时前
【自学笔记】版本控制与持续集成基础知识点总览-持续更新
笔记·ci/cd
Stream٩( 'ω' )و10 小时前
109~133笔记
笔记
weixin_5025398510 小时前
rust学习笔记2-rust的包管理工具Cargo使用
笔记·学习·rust
孤独得猿11 小时前
排序算法复习——包括插入排序、希尔排序、冒泡排序、快排(包括霍尔法、挖坑法、快慢指针法)、堆排、选择排序、归并排序等 (代码采用c/c++混编)
c语言·数据结构·c++·笔记·算法·排序算法
19999er12 小时前
框架&ThinkPHP(小迪网络安全笔记~
开发语言·笔记·安全·web安全·php
web_1553427465613 小时前
【合集】Java进阶——Java深入学习的笔记汇总 & 再论面向对象、数据结构和算法、JVM底层、多线程、类加载、
java·笔记·学习
rellvera13 小时前
【强化学习的数学原理】第08课-值函数近似-笔记
笔记