GIT的正确使用姿势与最佳实践——我与GIT(1)| 豆包MarsCode AI 刷题

68 阅读3分钟

课程之前,我与 Git 的初识

在正式学习 Git 之前,我已经与它有过一些初步接触。这得益于老师、学长以及组长的耐心指导和他们对开源文化的热情推广,让我得以结识这款功能强大的版本控制工具。在早期的团队合作项目中,我们为了更高效地管理代码版本并协调多人协作,选择使用 Git。

通过访问 GitHub(当然也可以选择国内的 Gitee 或 GitLab),我们可以创建和管理远程仓库,阅读他人的代码,甚至通过 Pull Request 提交自己的改进。

image.png 在本地开发中,我们将 Git 与 VS Code 相结合,通过设置 SSH 连接实现远程同步。

image.png 这种工作方式让我初步理解了 Git 的工作原理:

  • 在 VS Code 本地编写代码后,利用 commit 命令保存当前的开发进度;
  • 使用 branch 创建分支进行功能开发,确保主分支的稳定性;
  • 借助 VS Code 的扩展工具(如 GitLens),我们可以更方便地查看历史记录、比较代码差异,甚至可视化操作,极大提高了开发效率。

尽管如此,我的学习更多停留在基础操作上,并且部分功能是通过 VS Code 的可视化界面完成的,这在一定程度上降低了对 Git 内部逻辑的理解深度。但即便如此,这些基础操作依然让我体会到 Git 在协作开发中的价值。以下是我当时熟练掌握的基本命令:

  • git clone:从远端仓库拉取代码到本地,快速同步团队的最新代码。
  • git init:初始化一个新的 Git 仓库,为项目开启版本管理。
  • git pull:从远程仓库获取最新代码并自动合并到当前分支。
  • git push:将本地代码提交到远程仓库,确保团队成员能够共享最新的代码变更。
  • git fetch:从远程仓库拉取最新的变更记录,但不自动合并。
  • git status:检查当前代码的状态,了解哪些文件已修改但未提交。
  • git remote:管理远程仓库地址,帮助我们同步多个远端项目。
  • SSH 配置:通过生成 SSH 密钥,完成本地与远程仓库的安全连接,实现无密码操作。

虽然这些命令简单直接,但它们帮助我建立了初步的协作能力,也为后续的深入学习打下了基础。同时,我也逐渐意识到,当许多操作依赖于 VS Code 等工具的界面化操作时,虽然方便,但却让我对 Git 的底层逻辑了解得越来越少。


初识中的挑战与思考

项目开发过程中,我们并非一帆风顺。比如:

  • 当多个成员同时修改相同文件时,经常会遇到冲突问题,而初期的解决方法基本是“谁最后改,谁负责合并”,效率不高。
  • 有时因为操作失误导致历史记录被覆盖,甚至丢失重要代码版本。
  • 对如何有效管理多个分支、何时合并存在困惑,甚至直接在主分支上开发,增加了代码风险。

这些问题不仅让我认识到自身操作的不足,也让我产生了浓厚的兴趣:Git 为什么这么设计?有哪些更优雅的解决方案?我该如何更好地掌握这门工具?


写在最后

如果你也在学习 Git,不妨问问自己:

  • 你习惯通过命令行操作,还是依赖界面化工具?
  • 在使用 Git 的过程中,你遇到过哪些问题?是如何解决的?
  • 如果让你推荐一条最实用的命令,你会选择哪一个?

欢迎在评论区分享你的 Git 学习经历与心得,期待与你一起交流、进步!