
文章目录
-
- [**git pull(拉取更新)**](#git pull(拉取更新))
- [**git checkout(切换/恢复)**](#git checkout(切换/恢复))
-
- [1. **切换分支**](#1. 切换分支)
- [2. **恢复文件**](#2. 恢复文件)
- **关键区别对比**
- **典型工作流示例**
- **注意事项**
git pull 和 git checkout 是两个完全不同的 Git 命令,用途和功能有本质区别:
git pull(拉取更新)
-
用途:从远程仓库获取最新更改并合并到当前分支
-
本质 :相当于
git fetch+git merge(或git rebase) -
工作流程 :
- 下载远程仓库的最新提交
- 将远程分支的更改合并到当前本地分支
-
使用场景 :
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
注意事项
git pull前 确保工作目录干净,或使用git stash暂存更改git checkout会覆盖工作区的修改,使用前最好先提交或暂存- 从 Git 2.23 开始,建议使用:
git switch替代分支切换git restore替代文件恢复
简单记忆:git pull 用于"更新代码",git checkout 用于"切换上下文"。
结束语
Flutter是一个由Google开发的开源UI工具包,它可以让您在不同平台上创建高质量、美观的应用程序,而无需编写大量平台特定的代码。我将学习和深入研究Flutter的方方面面。从基础知识到高级技巧,从UI设计到性能优化,欢饮关注一起讨论学习,共同进入Flutter的精彩世界!