git 学习笔记

一、常用 git 命令

1.1 将本地分支的更新推送到远程仓库,并将本地分支与远程分支建立关联关系:
复制代码
git push -u origin <远程分支名>
1.2 将本地分支的更新推送到远程仓库,并且在推送的同时设置上游(upstream)分支。上游分支是指与本地分支关联的远程分支:
复制代码
git push --set-upstream origin <远程分支名>
1.3 从远程仓库拉取指定远程分支的更新,并将其合并到指定的本地分支,如果本地分支不存在则会创建,但不会被关联:
复制代码
git pull origin <远程分支名>:<本地分支名>
1.4 删除本地分支:
复制代码
git branch -d <本地分支名>
git branch -D <本地分支名>  # 强制删除,即使分支上有未合并的更改
1.5 删除远程分支:
复制代码
git push origin --delete <远程分支名>

二、commit message 命名规范

commit message 格式:<type>(<scope>): <subject>

type (必须,用于说明 git commit 的类别,只允许使用下面的标识):

  • feat:新功能(feature)。
  • fix/to:修复 bug。
    • fix:产生 diff 并自动修复此问题,适合于一次提交直接修复问题。
    • to:只产生 diff 不自动修复此问题,适合于多次提交,最终修复问题提交时使用 fix。
  • docs:文档(documentation)。
  • style:格式(不影响代码运行的变动)。
  • refactor:重构(即不是新增功能,也不是修改 bug 的代码变动)。
  • perf:优化相关,比如提升性能、体验。
  • test:增加测试。
  • chore:构建过程或辅助工具的变动。
  • revert:回滚到上一个版本。
  • merge:代码合并。
  • sync:同步主线或分支的 bug。

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

subject (必须,commit 目的的简短描述,不超过 50 个字符,结尾不加句号或其他标点符号)

三、git 分支合并发布流程

正常合并:

shell 复制代码
git add .  # 将所有新增、修改或删除的文件添加到暂存区
git commit -m "message"  # 将暂存区的文件提交
git status  # 查看是否还有文件没有发布上去
git checkout master  # 切换到要合并的分支
git pull  # 在 master 分支上拉取最新代码,避免冲突
git merge t231201  # 在 master 分支上合并 t231201 分支上的代码
git push  # 上传合并后的代码

存在合并冲突:

shell 复制代码
git checkout master  # 切换到要合并的分支
git pull  # 在 master 分支上拉取最新代码,避免冲突
git merge t231201  # 在 master 分支上合并 t231201 分支上的代码
# 如果存在合并冲突,在代码中解决冲突
git add .  # 将处理冲突后的代码提交到暂存区
git merge --continue  # 继续合并
git push  # 上传合并后的代码

参考:

https://zhuanlan.zhihu.com/p/182553920
https://blog.csdn.net/Fan0920/article/details/120128883
https://blog.csdn.net/qq_45677671/article/details/122574671

相关推荐
舒一笑33 分钟前
GitPulse:让代码的故事自己讲述
git·程序员·intellij idea
5***o5002 小时前
Git在代码中的GitHub
git·github
还是会想她2 小时前
git 常见命令
git
1***y1784 小时前
Git在发布流程中的自动化标签
运维·git·自动化
逻辑棱镜10 小时前
Git 分支管理与提交信息规范 (v1.0)
git·github·团队开发·代码规范·敏捷流程
悦悦欧呐呐呐呐12 小时前
git 设置邮箱和用户名
git
正经教主12 小时前
【Git】Git06:Git 管理 Android 项目教程(含GitHub)
android·git
艾莉丝努力练剑16 小时前
【Git:多人协作】Git多人协作实战:从同分支到多分支工作流
服务器·c++·人工智能·git·gitee·centos·项目管理
liuyao_xianhui1 天前
版本控制器git--gdb/cgdb
linux·运维·服务器·git
徐同保1 天前
如何使用GitKraken把git项目迁移到另一个平台,并保存所有提交记录,例如把github上的项目,迁移到gitee
git·gitee·github