入职第一天:先用Git管好你的代码!

这篇具有很好参考价值的文章主要介绍了入职第一天:先用Git管好你的代码!。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

本文并非面向完全的 Git 初学者,也不会详细介绍每一个 Git 命令和它的所有选项。相反,本文的目标读者是那些已经有一些基础,至少知道如何在本地仓库进行基本的版本控制操作,包括 git addgit commitgit log,但是还没有在企业环境中真正使用 Git 进行过项目开发的开发者们。

本文的目标是提供一种顺畅的过渡,帮助你更深入地理解如何在实际的项目开发中使用 Git,以及如何利用 Git 进行高效的团队协作。

提交规范

记住,每个提交都应该是有意义的更改,应附带明确的提交信息。这不仅可以帮助你回溯和理解每次更改的目的,而且还能帮助团队其他成员更好地理解你的更改。在提交规范中,你可以添加更多关于提交信息格式的建议,比如推荐的提交信息格式是:<type>: <subject>,这里的type可以是以下几种:

  • feat:新功能
  • fix:修复bug
  • docs:文档改变
  • style:代码格式改变(比如删除空格、格式化)
  • refactor:某个已有功能重构
  • perf:性能优化
  • test:增加测试
  • chore:构建过程或辅助工具的变动

subject则是对提交内容的简短描述。

分支管理

分支是 Git 中的核心概念,是实现并行开发和团队合作的重要工具。在这个章节中,本文会详细介绍如何在实际项目开发中高效使用分支。

开发流程

在一个典型的开发流程中,我们通常会有一个主分支(例如 mastermain),一个开发分支(例如 develop),以及针对特定功能或修复的特性分支(例如 feature/your_featurefix/your_fix)。

主分支通常包含了最新发布的或即将发布的代码,开发分支包含了正在开发的代码,而特性分支则是从开发分支切出来的,用于开发新功能或修复bug。

当新功能或修复完成后,我们会将特性分支合并回开发分支,然后在需要发布新版本时,我们会将开发分支合并到主分支,并打上相应的版本标签。

创建并切换分支

创建并切换到新的分支,我们可以使用 git checkout -b 命令:

git checkout -b new_branch

合并分支

要将一个分支的更改合并到当前分支,我们可以使用 git merge 命令:

git merge other_branch

请注意,合并前通常需要切换到目标分支,例如将开发分支合并到主分支:

git checkout master
git merge develop

分支的推送和删除

在你完成了特性分支上的工作后,你可以将其推送到远程仓库,并在确认无误后删除它:

git push origin feature_branch
git branch -d feature_branch

示例流程

以下是一种典型的分支管理示例流程:

1)首先,需要确保自己的本地 master 和 develop 分支是最新的。他们可以通过以下命令获取远程仓库的更新:

git checkout master
git pull origin master
git checkout develop
git pull origin develop

2)从 develop 分支创建 feature/new_feature 分支,并切换到 feature/new_feature 分支,然后在此分支上进行开发:

git checkout -b feature/your_feature # 创建并切换到一个新的功能分支

3)在feature/new_feature 分支上完成新功能的开发后,将新功能的代码提交到特性分支:

git add .
git commit -m "Add new feature"

4)提交代码后,需要将 feature/new_feature 分支推送到远程仓库,以便于其他团队成员进行代码审查:

git push origin feature/new_feature

5)代码审查无误后,项目经理或团队领导会将 feature/new_feature 分支合并到 develop master 分支。

因此,新入职员工主要的工作就是在自己的特性分_branch上进行开发,然后将完成的代码推送到远程仓库。其他的工作,例如合并分支、打标签等,通常由项目经理或团队领导来完成。

这样,我们就可以在复杂的项目开发中高效地使用 Git 分支进行团队协作了。

请注意,以上只是一种常见的分支管理策略(Git Flow),实际中可以根据项目的需要或者公司的规范来处理分支管理。

在任何情况下,关键是要确保代码的一致性和整洁性,以便于代码的维护和团队的协作。

短暂的工作中断

在你的开发过程中,可能会遇到需要临时切换到其他任务的情况,例如修复一个紧急的bug。在这种情况下,你可能还有一些未完成的修改,而你又不想为这些未完成的修改创建一个新的提交。此时,你可以使用 git stash 命令来保存你的修改。

git stash 命令会将所有未提交的修改(包括暂存区和工作目录的修改)保存起来,让你的工作目录回到最近的提交的状态。这样,你就可以自由地切换到其他任务,而不用担心你的未完成的修改会影响到你的新任务。

以下是使用 git stash 命令的基本步骤:

git stash # 保存你的修改
git checkout other_branch # 切换到其他任务
# ... 在其他任务中进行你的工作 ...
git checkout original_branch # 完成其他任务后,切回到原来的工作
git stash pop # 取回你保存的修改

在这里,git stash pop 命令会将你保存的修改取回到你的工作目录,并且从你的 stash 列表中删除这个 stash。如果你希望保留在 stash 列表中的副本,你可以使用 git stash apply 命令取回你的修改。

请注意,git stash 命令只会保存未提交的修改,不会保存任何未跟踪的文件(例如新创建的文件)。如果你想要保存未跟踪的文件,你需要使用 git stash -ugit stash --include-untracked 命令。

开发完成时

在你准备提交代码之前,你应该首先检查你的修改。你可以使用 git diff 命令查看你的修改,然后使用 git add . 将你的所有修改添加到暂存区。最后,使用 git status 来确认你是否已经添加了所有的修改。一旦确认你的所有修改都已被添加,你就可以提交你的代码了:

git diff # 检查你的修改
git add . # 添加所有的修改
git status # 确认你是否已经添加了所有的修改
git commit -m "你的提交信息" # 提交你的修改

提交后,你需要确保你的代码是最新的。使用git pull 来获取远程仓库的更新,然后使用 git merge 将这些更新合并到你的分支。最后,使用 git push 将你的分支推送到远程仓库:

git checkout master
git pull origin master
git checkout feature_branch
git merge master
git push origin feature_branch

冲突解决

在使用Git进行团队协作的时候,冲突是常见的问题,尤其是当多个人在同一段代码上做出修改的时候。当Git无法自动合并更改时,就会发生冲突。例如,当两个分支都修改了同一个文件的同一行,Git就不知道应该选择哪一个版本,就需要手动解决冲突。

首先,你需要确定哪些文件有冲突。你可以通过运行git status来查看这些文件。

接着,你需要打开这些文件,查找以下标记:

<<<<<<< HEAD
你的更改...
=======
别人的更改...
>>>>>>> branch-name

这些标记之间的内容就是发生冲突的地方。<<<<<<< HEAD之后,直到=======之间的部分是在你的分支(或HEAD)中的更改,=======>>>>>>> branch-name之间的部分是在别的分支中的更改。

你需要根据实际情况,保留需要的更改,删除不需要的更改以及Git添加的标记。可能需要保留你的更改,可能需要保留别的分支的更改,也可能需要合并你的更改和别的分支的更改。

完成冲突解决后,你应该再次检查你的修改,以确保他们的修改正如你所期望的那样。你可以使用 git diff 命令来查看你的修改。一旦你确定你的修改是正确的,你就可以将这些文件标记为冲突已解决,并提交你的修改了:

git diff # 再次检查你的修改
git add conflicted_file # 将这些文件标记为冲突已解决
git commit -m "Resolved conflicts" # 提交你的修改

这样,你就成功地解决了冲突,可以继续你的工作了。

版本回退or测试

在编程开发中,尤其是在使用Git这样的版本控制系统时,版本回退是非常重要的一个环节。当我们发现最新的更改导致了某些问题,或者我们只是想要查看或测试某个旧的版本时,我们可以使用Git的版本回退功能。

在回退之前,要么提交当前的修改,要么先使用git stash命令保存未提交的修改,防止回退操作丢失这些修改。

但是请注意,回退到旧的commit后,任何新的commit都将基于这个旧的commit。也就是说,如果你在回退之后进行了一些修改,并提交了这些修改,那么这些新的commit将不包含回退之前的commit。这种情况下,你应该在回退的版本基础上创建新的分支,然后在新的分支上进行修改和测试。以下是这个流程的步骤:

git checkout -b testing_branch # 创建并切换到一个新的测试分支
git reset --hard <commit_hash> # 回退到需要测试的版本
git push origin testing_branch # 将旧的代码推送到新的远程分支进行测试

测试完成后,如果你想回到最新的代码,你可以切换回你的工作分支。你的测试代码还被保留在了一个分离的分支上,如果不再需要测试分支,你可以选择删除它。

git checkout feature_branch # 切换回工作分支
git branch -d testing_branch # 删除测试分支(可选)

配置和优化Git环境

在Java开发中,.gitignore文件是一个非常重要的配置文件。它告诉Git哪些文件不应该被版本控制系统追踪。

例如,你可能想要Git忽略target/目录,这个目录通常包含了Java的编译结果。你可能也想要Git忽略IDE生成的项目配置文件,比如IntelliJ IDEA的.idea/目录和.iml文件。还有一些包含敏感信息的文件,比如包含数据库密码的application.properties文件,也应该被忽略。

一个典型的Java项目的.gitignore文件可能是这样的:

target/
*.iml
.idea/
application.properties

只需将上述内容添加到你的项目根目录下的.gitignore文件中,Git就会自动忽略这些文件和目录。

希望这篇文章能够帮助你在实际项目开发中更有效地使用 Git,提高你的团队协作效率。文章来源地址https://www.toymoban.com/news/detail-541741.html

到了这里,关于入职第一天:先用Git管好你的代码!的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Java后端入职第六天,Nginx搭建负载均衡+反向代理

    Nginx相信大家应该不陌生吧!是一个高性能web服务器,可以做负载均衡或者是反向代理,比如,把静态页面直接部署到到html,实现动静分离,一个服务器部署多个服务,缓解服务压力,等等,都可以利用Nginx实现。 这个理解比较简单,其实就是压力分摊,一个工程部署多个节

    2024年02月08日
    浏览(66)
  • 代码随想录第一天

    1.1 class solution class表示声明一个类,solution表示解决方案。那么class Solution就是声明一个解决方案的类,类中用来存放关于解决这一问题所需要的各种函数和变量。 这样做的好处有: 生成若干实例互不干扰,每个类的实例内部的(非静态)成员变量是独立的。 对主函数没有任

    2024年02月06日
    浏览(35)
  • 【代码随想录算法第一天| 704.二分查找 27.移除元素】

    题目链接:二分查找 文章讲解:代码随想录.二分查找 视频讲解:手把手带你撕出正确的二分法 | 二分查找法 | 二分搜索法 | LeetCode:704. 二分查找_哔哩哔哩_bilibili 二分前提:有序数组,数组中无重复元素 方法:结合数组的特征,可以为左闭右闭区间[0, 数组长度-1],或者左

    2024年02月16日
    浏览(45)
  • 代码随想录图论 第一天 | 797.所有可能的路径 200. 岛屿数量

    代码随想录图论 第一天 | 797.所有可能的路径 200. 岛屿数量 一、797.所有可能的路径 题目链接:https://leetcode.cn/problems/all-paths-from-source-to-target/ 思路:求从0到n-1的所有路径,终止条件是当前节点为n-1。本题图的结构是group[][],group[x]表示x节点所能到达的所有节点的集合,深度

    2024年02月08日
    浏览(54)
  • 代码随想录第一天 | LeetCode704.二分查找,LeetCode 27.移除元素

    数组理论基础要点: 数组也是数据结构的一种, 是存放在连续内存空间上的相同类型数据的集合。 数组注意点: 数组下标都是从0开始的。 数组内存空间的地址是连续的。 因为上述两点, 数组的在内存空间的地址是连续的,所以我们在删除或者增添元素的时候,就难免要

    2024年02月08日
    浏览(50)
  • LeetCode 1997.访问完所有房间的第一天:动态规划(DP)——4行主要代码(不需要什么前缀和)

    力扣题目链接:https://leetcode.cn/problems/first-day-where-you-have-been-in-all-the-rooms/ 你需要访问  n 个房间,房间从 0 到 n - 1 编号。同时,每一天都有一个日期编号,从 0 开始,依天数递增。你每天都会访问一个房间。 最开始的第 0 天,你访问  0 号房间。给你一个长度为 n 且 下标从

    2024年04月14日
    浏览(38)
  • C++实战Opencv第一天——win11下配置vs,opencv环境和运行第一个c++代码(从零开始,保姆教学)

    OpenCV (Open Source Computer Vision Library)是一个开源的计算机视觉和机器学习软件库,它提供了大量的通用算法和功能,用于处理图像和视频数据。 C++ 通常提供比 Python 更高的执行速度 ,对于需要高性能处理的任务(如 实时视频处理或大规模图像分析 ) 。C++ 提供更细致的 内

    2024年01月19日
    浏览(51)
  • 前端新员工入职,需要为你的新电脑安装一些环境,开发工具

    目录 一.先安装个谷歌浏览器,稳定版。 二.安装公司日常交流软件 三.安装个VSCode 四.安装nvm 五.vue-cli的安装和配置 六.安装git 配置git账号 拉取线上仓库到本地 一些常用git命令 GitLab配置公钥私钥  七.其他工具 网络抓包工具:whistle 反向代理工具:nginx 调试接口工具:postma

    2024年02月06日
    浏览(61)
  • 用 git 和 gitee管理你的代码

    ---------------------------------------------------------------------------------------------------- -----------------写在前面的准备工作------------------------------------------- ----------------------------------------------------------------------------------------------------- 如果你还没有安装git,请下载安装,百度一下 Git 安装与

    2024年02月19日
    浏览(39)
  • git常用命令,git第一次拉取代码

    2024年02月13日
    浏览(48)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包