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的精彩世界!

相关推荐
海鸥813 小时前
in argocd ‘/tmp/_argocd-repo/../.git/index.lock‘: No space left on
git·argocd
尔嵘4 小时前
git操作
大数据·git·elasticsearch
大柏怎么被偷了6 小时前
【Git】企业级开发模型
git
Garfield20056 小时前
Git 分支拓扑实践
git·拓扑
DKNG6 小时前
【Windows Host】 hosts配置增加访问github流畅度
人工智能·git·github
一个很帅的帅哥9 小时前
git命令大全
大数据·git·elasticsearch
凯子坚持 c9 小时前
Git 远程仓库操作与深度进阶指南
git
勇敢牛牛_9 小时前
RustRover 2025.3 在WSL中GIT操作十分缓慢的问题
git·rust·rustrover
编程小白gogogo11 小时前
创建git仓库并推送苍穹外卖初始项目
git