代码工程必备能力—Commit 规范

Git是目前应用最为广泛的开源分布式版本控制系统,不论是对企业团队还是科研任务都需要掌握使用Git的技巧,文章重点在于总结如何使用Git的一些功能,包括讲述的文章、资源和个人的想法。

Git 官方网址:Git

一. Git Commit 的作用(干啥用的)

        Git Commit:指的是提交说明,用于标注此次修改的内容以及需要提示的信息,官方给出的解释是:Record changes to the repository(记录添加到仓库当中的修改)。

        提供一个场景来做理解:

        代码团队合作编写项目A,我作为开发人员从 Github 拉取代码到本地创建了分支A_1,并在这个分支上做了修改。假定这个修改的内容是为项目代码的某个文件增加了功能模块,将这部分修改提交到缓存当中,执行:

git add .

        我想将工程上传到Github当中并希望团队的负责人审查之后,将我的功能模块并入到主模块当中,这个时候就需要告诉这个负责人我修改了什么,尤其在面对非常多的提交的时候,让负责人尽快地定位到关键内容,查看Commit信息就显得非常重要了。

        当然,Commit对于自己维护代码和查看工作进程等方面都有非常重要的作用,每一个计算机人员在使用Git管理工程时候都应当保有Commit的习惯。

二. Git Commit 的正确打开方式(怎么用)

        Git Commit命令用于将更改记录(提交)到存储库。将索引的当前内容与描述更改的用户和日志消息一起存储在新的提交中,以下是Git Commit命令的具体参数列表

git commit [-a | --interactive | --patch] [-s] [-v] [-u<mode>] [--amend]
	   [--dry-run] [(-c | -C | --squash) <commit> | --fixup [(amend|reword):]<commit>)]
	   [-F <file> | -m <msg>] [--reset-author] [--allow-empty]
	   [--allow-empty-message] [--no-verify] [-e] [--author=<author>]
	   [--date=<date>] [--cleanup=<mode>] [--[no-]status]
	   [-i | -o] [--pathspec-from-file=<file> [--pathspec-file-nul]]
	   [(--trailer <token>[(=|:)<value>])…​] [-S[<keyid>]]
	   [--] [<pathspec>…​]

常用的有三种参数形式:

1. 命令行直接添加修改信息

git commit -m "描述提交修改的信息"

2. 使用文本编辑器添加修改信息

git commit

直接使用指令会弹出电脑的默认编辑器,然后直接编辑内容即可。当保存(Ctrl + S)之后关闭编辑器就完成了此次提交。

3. -a 会先把所有已经track的文件改动`git add`进来,直接提交而不需要每次都先执行Git add . 

git commit -a

4. -amend 是增补提交,会使用与当前提交节点相同的父节点进行一次新的提交,旧的提交将会被取消,这样就不需要为了修改Commit的内容而再次提交一次。

git commit --amend

 关于Git Commit更多的详细使用方式:

廖雪峰: 简单直接上手的Git Commit操作和讲解

易百教程: 详细讲述了Git  Commit和 Git  Add 之间的恩怨情仇

官网:每一个参数的具体解释

可视化使用Commit教程:IDEASourceTree , TortoiseGit

一般每一个IDE只要右键都能够发现对应的Git选项,其中会集成一部分功能的可视化。

三. Git Commit 的行业规范(遵守的规矩)

Git Commit 最大的价值就是标注信息,那如何才能够最高效地标识清楚修改的内容就是Git Commit的最大意义。

目前,社区有多种 Commit message 的写法规范。本文介绍Angular 规范是目前使用最广的写法,比较合理和系统化,并且有配套的工具。前端框架Angular.js采用的就是该规范。

目的是:
 

  • 可读性好,清晰,不必深入看代码即可了解当前commit的作用。

  • 为 Code Reviewing做准备

  • 方便跟踪工程历史

  • 让其他的开发者在运行 git blame 的时候想跪谢

  • 提高项目的整体质量,提高个人工程素质

以下是在GitHub 上查看提交修改时候的界面

 来看其中具体的一条

 按照这个标准,规定Commit的文字部分格式:

格式要求包括三个部分: Header,Body和Footer;其中,header 是必需的,body 和 footer 可以省略。

<type>(<scope>): <subject>
<BLANK LINE> #空行的意思
<body>
<BLANK LINE>
<footer>

1.  Header:

        Header部分只有一行,包括三个字段:type 、scope、subject

        这三部分分别对应图片当中红蓝黄三个部分的内容,一个比较好的Commit信息,应当包含完全必要的修改内容。

type 用于说明 commit 的类别,只允许使用下面7个标识。 
> feat:新功能(feature)
> fix:修补bug 
> docs:文档(documentation)
> style: 格式(不影响代码运行的变动)
> refactor:重构(即不是新增功能,也不是修改bug的代码变动)
> test:增加测试
> chore:构建过程或辅助工具的变动

scope
scope用于说明 commit 影响的范围,比如数据层、控制层、视图层等等,视项目不同而不同。

例如在Angular,可以是$location, $browser, $compile, $rootScope, ngHref, ngClick, ngView等。

如果修改影响了不止一个scope,你可以使用*代替。
subject是 commit 目的的简短描述,不超过50个字符。

其他注意事项:

以动词开头,使用第一人称现在时,比如change,而不是changed或changes,第一个字母小写,结尾不加句号(.)

2. Body

Body 部分是对本次 commit 的详细描述,可以分成多行。下面是一个范例。

More detailed explanatory text, if necessary.  Wrap it to 
about 72 characters or so. 

Further paragraphs come after blank lines.

- Bullet points are okay, too
- Use a hanging indent

有两个注意点:

  • 使用第一人称现在时,比如使用change而不是changed或changes。

  • 永远别忘了第2行是空行

  • 应该说明代码变动的动机,以及与以前行为的对比。

3. Footer

(1)不兼容变动

BREAKING CHANGE: isolate scope bindings definition has changed.

    To migrate the code follow the example below:

    Before:

    scope: {
      myAttr: 'attribute',
    }

    After:

    scope: {
      myAttr: '@',
    }

    The removed `inject` wasn't generaly useful for directives so there should be no code using it.

 以BREAKING CHANGE开头的Footer,主要用在当前代码和上一个版本不适应的时候

(2)关闭 Issue

如果当前 commit 针对某个issue,那么可以在 Footer 部分关闭这个 issue 。

Closes #265

参考资料:

[1] Git Commit Message StyleGuide: slashsbin/styleguide-git-commit-message: /sBin/StyleGuide/Git/CommitMessage (github.com)

[2]  Commit message 和 Change log 编写指南 BY 阮一峰:  Commit message 和 Change log 编写指南 - 阮一峰的网络日志 (ruanyifeng.com)

[3] Abe Stanway // abe.is

[4] Git Commit Message Conventions: Git Commit Message Conventions - Google 文档

[5] GitKraken -- 超好用的 Git 可视化工具 - 知乎 (zhihu.com)

<think>好的,用户让我介绍一下现在作为一个专业的代码工程师的情况。首先,我需要明确用户的需求是什么。可能他们想了解作为代码工程师需要具备哪些技能,或者如何在这个领域发展。也有可能他们自己有兴趣进入这个行业,想了解相关信息。 接下来,我应该考虑用户的背景。他们可能是学生、刚入行的开发者,或者非技术背景的人士。不同的背景需要不同的解释方式。如果是学生,可能需要强调学习路径和必备技能;如果是转行者,可能需要更多关于实践和项目经验的内容。 然后,我需要组织回答的结构。通常,介绍一个职业可以从职责、技能要求、工具使用、工作流程、发展方向等方面展开。这样能让用户全面了解这个角色。同时,要使用通俗易懂的语言,避免过于专业的术语,或者如果使用术语的话,要简单解释一下。 还要注意用户可能关心的点,比如薪资水平、行业前景、挑战等。虽然用户没有明确提到,但作为补充信息可能会有帮助。不过,避免猜测过多,主要围绕用户的问题展开。 另外,用户提到“现在是一个专业的代码工程师”,可能需要强调当前行业的趋势,比如人工智能、云计算、大数据等领域的影响,以及持续学习的重要性。这部分内容能让用户了解行业动态,帮助他们做出更明智的职业规划。 需要检查是否有遗漏的关键点。比如,是否提到团队协作、沟通能力等软技能?这些都是专业代码工程师不可或缺的部分。同时,代码质量、测试、调试等实际工作中的细节也应该涵盖。 最后,确保回答符合之前设定的格式要求:使用中文,行内公式用$...$,独立公式用$$...$$并单独成段。虽然当前问题可能不涉及数学公式,但如果有相关内容出现,需要遵循规则。此外,保持回答结构清晰,分点说明,便于用户阅读和理解。 总结下来,回答应该包括角色定义、核心技能、常用工具、工作流程、发展方向,以及持续学习的重要性。每个部分用简短的段落或列表呈现,确保信息传达有效。同时,保持语言自然,避免生硬,让用户感受到有帮助且易于理解。</think>作为专业代码工程师,我的核心能力体现在以下结构化框架中: $$System\ Design = \sum_{i=1}^{n}(Requirement\ Analysis_i + Architecture\ Design_i)$$ 一、核心技能矩阵 1. 语言栈深度 - 主语言生态:$Java/Kotlin \Rightarrow Spring\ Boot \pm gRPC \otimes Kubernetes$ - 脚本语言:$Python \oplus Bash \rightarrow DevOps\ Automation$ - 前端协同:$TypeScript \bowtie React\ Hooks$ 2. 工程能力 ```mermaid graph TD A[代码规范] --> B(CI/CD Pipeline) B --> C[SonarQube] C --> D{Code Review} D -->|通过| E[Artifact Registry] D -->|拒绝| F[迭代优化] ``` 二、开发范式演进 $$Efficiency = \frac{\sum Test\ Coverage}{Debug\ Time} \times \prod_{k=1}^{m}Auto\ Tool_k$$ 三、典型工作流 1. 需求阶段:$User\ Story \Rightarrow UML\ Sequence\ Diagram$ 2. 实现阶段: ```python def implement(): while not meet_definition_of_done(): try: code_refactoring() write_unit_test() except TechnicalDebt as e: apply_design_pattern() ``` 3. 交付阶段:$GitFlow \rightarrow Blue/Green\ Deployment$ 四、质量保障体系 $$Quality = \int_{commit}^{prod} (Static\ Analysis + E2E\ Testing) \,dt$$ 五、持续学习路径 $$Learning\ Curve = \sum_{year=2010}^{2023} (New\ Framework^{year} \times OSS\ Contribution)$$ 这个专业体系通过$Agile\ Sprints$持续迭代,结合$Architecture\ Decision\ Records$保持技术演进的可追溯性。当前正在探索$AI\ Code\ Generation$与$Human\ Review$的协同边界。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值