IDEA中Git常用操作及Git存储原理
创始人
2025-01-07 12:03:37
0

Git简介与使用

Intro

Git is a free and open source distributed version control system designed to handle everything from small to very
large projects with speed and efficiency.

Git是一款分布式版本控制系统(VCS),是团队合作开发的必备工具。

Git Repository 本地可划分为3个区域:

  • workspace
  • staging area
  • local repository

其交互示意图如下:
在这里插入图片描述

git基本的命令操作可以参看:Git教程

Using within Jetbrains IDE

Jetbrains全家桶提供了对Git的支持,下面以IDEA 2024.1.4版本演示Git基本操作。

IDEA使用不同的颜色表明文件在Git中的状态,如下所示为Darcula主题下颜色的含义:

在这里插入图片描述

具体颜色含义可参看:Check file status

rollback

如果我本地改动了文件,但发现改动无效,想回到改动之前的文件状态,可以右击文件 -> Git -> Rollback:
在这里插入图片描述

commit & amend commit & commit checks

使用IDEA commit窗口可以方便地选择需要commit的文件,填写commit信息。此外如果上一次commit有东西忘写了,这次写完使用amend
commit将上次和这次改动合并成一次commit,在commit窗口勾选amend即可。

在这里插入图片描述

每次commit前需要有些前置校验呢?比如自动格式化代码、自动checkstyle,IDEA也提供了该项功能:在commit窗口,点击设置图标,勾选所需checks

1.设置2.勾选
在这里插入图片描述在这里插入图片描述
squash commit

如果我们要将多次提交合并成一个提交,可以定位到当前本地分支,并多选多条commit进行squash:

在这里插入图片描述

此时push就需要强制push了

rebase

当master代码有变动时,基于老master版本开发的本地feature分支需要rebase到最新代码(即把master分支新代码合并到本地feature开发commit之前),使用IDEA操作:

  1. 拉取master最新代码 git pull
  2. 切换到feature分支
  3. 执行rebase
1. 拉取master最新代码2.执行rebase
在这里插入图片描述在这里插入图片描述
cherry-pick

合作开发时,比如A同学在feature-a分支开发功能,B同学在feature-b分支开发,且feature-b分支依赖feature-a分支的功能,即feature-b分支基于feature-a分支的commit开发。
如果feature-a分支的commit有改动,则feature-b就要同步这些改动,且需要保证feature-b分支的commit不会凌乱,这时可使用cherry-pick来完成。

  1. 拉取feature-a最新代码;
  2. 复制分支feature-bfeature-b-bak
  3. feature-b执行reset --hardfeature-a的最早commit之前的一次commit;
  4. feature-bcherry-pick 新的feature-a的commit
  5. feature-bcherry-pick 复制的feature-b-bak的自己的commit
reset --hardcherry-pick
在这里插入图片描述在这里插入图片描述
ref
  • Boost Your Productivity: 13 Pro Git Tips for JetBrains IDEs

Git存储原理

git中有三种类型的文件:

  • blob: 压缩存储的二进制文件内容
  • tree: 表示项目文件夹,tree下包含subtree和blob,以及blob对应文件的文件名、访问权限等信息,使用Merkel Hash Tree数据结构构建
  • commit: 包含指向的tree和提交信息

3种类型文件均存储于./.git/objects/文件夹下,利用40位的SHA的hash值的前2位作为文件夹,后38位作为文件名,其组织形式如下图:
在这里插入图片描述

假设git项目文件夹下有一个a.txt文件,执行完git add .git commit -m "first commit"./.git/objects/文件夹新增3个objects:

.git > watch -n .5 tree .git ... ├── objects │    ├── 08 │    │    └── 585692ce06452da6f82ae66b90d98b55536fca │    ├── 47 │    │    └── d94322168b96993a93f2346c8eafd50bcc8317 │    ├── 78 │    │    └── 981922613b2afb6025042ff6bd878ac1994e85 |... 

而分支是指向commit hash的一个引用,其存储在 .git/refs/heads/下:

> pwd /Users/bty/IdeaProjects/testgit/.git/refs/heads > ls feature-a	main > cat main  47d94322168b96993a93f2346c8eafd50bcc8317 

HEAD表示当前的分支,指向 .git/refs/heads/的一个文件:

> pwd /Users/baotingyu/IdeaProjects/testgit/.git > ls COMMIT_EDITMSG	config		hooks		info		objects HEAD		description	index		logs		refs > cat HEAD  ref: refs/heads/feature-a 

objects文件类型可通过git cat-file -t [40位hash]查看:

 > git cat-file -t 78981922613b2afb6025042ff6bd878ac1994e85 blob  > git cat-file -t 08585692ce06452da6f82ae66b90d98b55536fca tree  > git cat-file -t 47d94322168b96993a93f2346c8eafd50bcc8317 commit  

以上文件的内容均可以通过git cat-file -p [40位hash]

 # 查看一个blob,显示文件内容(不包含文件名,访问权限等信息,都在tree里面) > git cat-file -p 78981922613b2afb6025042ff6bd878ac1994e85 a  # 查看一个tree,显示tree下的内容(子tree或blob) > git cat-file -p 08585692ce06452da6f82ae66b90d98b55536fca 100644 blob 78981922613b2afb6025042ff6bd878ac1994e85	a.txt  # 查看一个commit,包含指向的tree和提交信息 > git cat-file -p 47d94322168b96993a93f2346c8eafd50bcc8317 tree 08585692ce06452da6f82ae66b90d98b55536fca author bty  1720876267 +0800 committer bty  1720876267 +0800  first commit  

相关内容

热门资讯

推荐透视!德普之星透视免费,德... 推荐透视!德普之星透视免费,德普之星透视辅助软件,竟然真的有辅助软件(哔哩哔哩)1、在插件功能辅助器...
揭幕透视!wepoker养号规... 揭幕透视!wepoker养号规律,wepoker有辅助器吗,果然一直总是有辅助app(哔哩哔哩)是不...
推荐透视!wpk刷入池率脚本,... 推荐透视!wpk刷入池率脚本,购买的wpk辅助在哪里下载,切实一直总是有辅助app(哔哩哔哩)1、下...
透视透视!如何判断wpk辅助软... 透视透视!如何判断wpk辅助软件的真假,如何下载wpk透视版,切实一直总是有辅助教程(哔哩哔哩)破解...
普及透视!wpk辅助插件,wp... 普及透视!wpk辅助插件,wpk有作比弊吗,总是存在有辅助app(哔哩哔哩)1、在插件功能辅助器技巧...
详细透视!hhpoker德州透... 详细透视!hhpoker德州透视挂,hhpoker的辅助是真的吗,一直一直都是有辅助攻略(哔哩哔哩)...
关于透视!德普辅助软件,如何下... 关于透视!德普辅助软件,如何下载德普之星辅助软件,一贯一直总是有辅助工具(哔哩哔哩)1、完成有辅助插...
解谜透视!wpk作比弊,wpk... 解谜透视!wpk作比弊,wpk作比弊,确实是真的有辅助教程(哔哩哔哩)1、每一步都需要思考,不同水平...
关于透视!德普之星私人局辅助免... 关于透视!德普之星私人局辅助免费,德普之星透视免费,一贯是有辅助方法(哔哩哔哩)1、起透看视 辅助软...
关于透视!wpk有那种辅助吗,... 关于透视!wpk有那种辅助吗,wpk安卓下载辅助,本来有辅助攻略(哔哩哔哩)亲,关键说明,透视脚本安...