git pull和git checkout在恢复文件的区别

文章目录

git pullgit checkout 是两个完全不同的 Git 命令,用途和功能有本质区别:

git pull(拉取更新)

  • 用途:从远程仓库获取最新更改并合并到当前分支

  • 本质 :相当于 git fetch + git merge(或 git rebase

  • 工作流程

    1. 下载远程仓库的最新提交
    2. 将远程分支的更改合并到当前本地分支
  • 使用场景

    bash 复制代码
    # 拉取远程仓库的最新代码到当前分支
    git pull origin main
    
    # 拉取并变基(避免不必要的合并提交)
    git pull --rebase origin main

git checkout(切换/恢复)

  • 用途:切换分支 或 恢复文件
  • 两种主要用法

1. 切换分支

bash 复制代码
# 切换到已存在的分支
git checkout main

# 创建并切换到新分支
git checkout -b new-feature

# 切换到远程分支(会自动创建本地分支跟踪远程分支)
git checkout -b feature origin/feature

2. 恢复文件

bash 复制代码
# 丢弃工作区的修改,恢复到最近一次提交的状态
git checkout -- filename.txt

# 恢复到特定提交的文件版本
git checkout commit-hash -- filename.txt

关键区别对比

特性 git pull git checkout
主要目的 同步远程代码 切换分支或恢复文件
网络操作 需要网络连接 通常不需要网络
改变内容 更新当前分支内容 改变工作目录状态
风险级别 可能产生合并冲突 可能丢失未提交的更改

典型工作流示例

bash 复制代码
# 1. 同步最新代码
git pull origin main

# 2. 创建新分支开发
git checkout -b feature-branch

# 3. 开发完成后切换回主分支
git checkout main

# 4. 再次拉取最新代码
git pull origin main

# 5. 合并功能分支
git merge feature-branch

注意事项

  1. git pull 确保工作目录干净,或使用 git stash 暂存更改
  2. git checkout 会覆盖工作区的修改,使用前最好先提交或暂存
  3. 从 Git 2.23 开始,建议使用:
    • git switch 替代分支切换
    • git restore 替代文件恢复

简单记忆:git pull 用于"更新代码",git checkout 用于"切换上下文"


结束语

Flutter是一个由Google开发的开源UI工具包,它可以让您在不同平台上创建高质量、美观的应用程序,而无需编写大量平台特定的代码。我将学习和深入研究Flutter的方方面面。从基础知识到高级技巧,从UI设计到性能优化,欢饮关注一起讨论学习,共同进入Flutter的精彩世界!

相关推荐
vibecoding日记1 天前
为什么我就想要「线性历史 + Signed Commits」,GitHub 却把我当猴耍 🤬🎙️
git·编程工具
程序员小崔日记1 天前
如何将代码轻松上传到 Gitee?Git 使用全攻略!
git·gitee·上传
Bigger2 天前
为什么你的 Git 提交需要签名?—— Git Commit Signing 完全指南
git·开源·github
DianSan_ERP3 天前
电商API接口全链路监控:构建坚不可摧的线上运维防线
大数据·运维·网络·人工智能·git·servlet
红豆子不相思3 天前
Tomcat 环境搭建与集群实战
服务器·git·tomcat
杰哥技术分享3 天前
Git 仓库迁移技术文档:从 CODING.net 迁移至腾讯云 CNB
git
梅孔立3 天前
Ansible 100 台服务器一键管控实战 进阶版
服务器·git·ansible
qq_426003964 天前
git切换当前分支到远程分支
git
ON10N4 天前
100% 纯 Vibe Coding,我是怎么用 AI 撸出一个 VS Code 插件的
git·ai编程·visual studio code