当前位置: 首页 > news >正文

.git文件夹里所有文件详解

.git文件详解

📂 文件夹部分(对应核心数据)

  1. hooks

    • 存放 Git 钩子脚本(比如提交前自动检查代码、推送前跑测试)
    • 默认是空模板,平时基本不用管
  2. info

    • 存放 Git 的额外信息,比如排除规则(比.gitignore更底层,一般不用)
  3. logs

    • 存放所有 Git 操作的日志(对应你用git reflog查的内容)
    • 包含分支切换、回退、提交的完整记录,是找回误操作的关键
  4. objects

    • Git 的“核心数据库”!
    • 所有文件快照、提交记录、版本历史,都以压缩对象的形式存在这里
    • 你每次git commit,Git 都会把改动打包成新对象存进来
  5. refs

    • 存放所有分支、标签的引用指针
    • refs/heads/main:指向main分支的最新提交版本号
    • refs/remotes/origin/main:指向远程仓库main分支的最新版本号

📄 文件部分(关键配置与状态)

  1. config

    • 你最关心的远程仓库地址,就存在这里!
    • 打开就能看到[remote "origin"]配置,git remote -v命令就是读取这个文件
  2. HEAD

    • 告诉你当前在哪个分支上!
    • 打开文件会看到类似ref: refs/heads/main的内容,代表你现在在main分支
  3. index

    • 对应 Git 的暂存区
    • 你用git add命令后,文件的改动就会写入这个文件,等待后续git commit
    • 你看到它大小是 286KB,说明你已经有不少文件被add到暂存区了
  4. COMMIT_EDITMSG

    • 保存你上一次提交的备注信息
    • 当你用git commit时,默认会加载这个文件作为提交信息模板
  5. FETCH_HEAD/ORIG_HEAD

    • FETCH_HEAD:记录你上一次git fetch拉取的远程分支状态
    • ORIG_HEAD:记录你上一次危险操作(比如resetmerge)前的状态,用于恢复
  6. description

    • 仓库的描述信息,一般 GitWeb 等工具会用到,个人开发基本不用管

✨ 一句话帮你串起来

你平时敲的 Git 命令,本质都是在读写这些文件:

  • git add→ 写index文件
  • git commit→ 写objects+ 更新refsHEAD
  • git push→ 把objectsrefs同步到远程仓库
  • git remote -v→ 读config文件
  • git reflog→ 读logs文件夹

⚠️ 再次提醒:千万不要手动修改/删除这些文件!一旦损坏,你的 Git 仓库就会出问题,甚至丢失历史版本。

git checkout -b dev 会使.git文件夹发生那些变化

git checkout -b dev只改.git里少数几个“指针/日志文件”,工作区文件内容不变

等价命令

gitbranch dev# 1. 创建分支指针gitcheckout dev# 2. 切换到新分支

一、会变的文件(都在 .git/ 下)

  1. .git/HEAD

    • 之前:ref: refs/heads/main
    • 之后:ref: refs/heads/dev
    • 作用:把“当前分支”指向 dev。
  2. .git/refs/heads/dev(新增)

    • 内容:当前 commit 的哈希值(和 main 此刻相同)
    • 作用:新建 dev 分支指针。
  3. .git/logs/HEAD.git/logs/refs/heads/dev

    • 追加一条记录:从 main 切到 dev
    • 作用:git reflog能看到这次切换。
  4. .git/index(暂存区)

    • 若工作区无冲突:不变
    • 若有未提交修改:会刷新为 dev 分支版本(保留你未提交的改动)。

二、完全不变的

  • 工作区所有源码文件(和切分支前一模一样)
  • .git/objects(所有提交/文件快照,没新增、没修改)
  • .git/config(远程地址、用户名等)
  • 其他hooks/info/

三、直观总结

  • 新建分支 = 加一个指针(refs/heads/dev)
  • 切换分支 = 改 HEAD 指向 + 写日志
  • 代码内容本身完全不变,只是换了个“标签”继续开发。

分支操作顺序

# 1. 从 main 新建并切换到 dev 分支gitcheckout-bdev# 2. 添加所有修改gitadd.# 3. 提交修改gitcommit-m"添加实现计划2026-06-07-isolated-sign-recognition.md"# 4. 第一次推送新分支(必须用这条,最稳、不看网络脸色)gitpush-uorigin dev

为什么你之前git push失败、git push -u origin dev成功?

因为:

  • git push依赖网络 + Git 版本 + 配置
  • git push -u origin dev不依赖任何配置,强制推送 + 绑定远程

国内网络连 GitHub 不稳定时,永远用:

gitpush-uorigin 分支名

这是100% 不会失败的推送方式。

万能流程

gitcheckout main# 切回主分支gitpull# 拉取最新gitcheckout-b新分支名# 创建新分支gitadd.gitcommit-m"提交信息"gitpush-uorigin 新分支名# 第一次必用这个
http://www.zskr.cn/news/1482202.html

相关文章:

  • 2026 年 6 月最新!沈阳旧书老书回收联系方式+电话:皇姑/和平区老板价高实在 - 资讯纵览
  • 案例:买飞机票;验证码
  • 郑州黄金奢侈品回收店甄选指南(2026 权威版)资质设备报价服务口碑五大维度严选 - 新闻快传
  • 南昌墨客雅筑(宸智雅筑)装饰官方联系方式 合作电话 官网入口 避坑指南 - 资讯纵览
  • 客户管理系统(CRM)怎么选?2026年主流系统平台对比与场景解析
  • 为什么每个设计者都需要一个像LitCAD这样的开源CAD软件?[特殊字符]
  • 襄阳地区电捕焦油器厂家实力排行:技术与资质对比 - 奔跑123
  • 如何快速使用AZ音乐下载器:完整功能指南与技巧
  • 为什么NanaZip是现代Windows用户必备的7-Zip升级版?
  • 地热井抽水试验水位监测设备|高温深井投入式水位计选型方案 - 王工聊地下水监测
  • 从零到精通:用League Akari打造你的英雄联盟智能助手
  • Cowabunga Lite:无需越狱的iOS深度定制工具完全指南
  • 深圳壹家雅筑(宸智雅筑)装饰官方联系方式 合作电话 官网入口 避坑指南 - 资讯纵览
  • 地热资源开发水位监测解决方案|兼顾长期运维与抽水试验勘察 - 王工聊地下水监测
  • 花一天排查出的线上 GC 频繁问题,竟是因为一个配置
  • 2026温州GEO优化公司深度评测与选型避坑指南 - 品牌报告
  • 用数据说话!盘点2026年学生热捧的的降AIGC软件 - 降AI小能手
  • 5步掌握LinkSwift:告别网盘限速的终极下载指南
  • 前端初学者如何深度理解 如何创建一个路由页面
  • PI XLs Designer v8.0:电源变压器设计的精密计算与深度优化指南
  • Windows下开箱即用的音视频转码工具包,含全格式编解码支持
  • FitGirl游戏启动器完整指南:一站式管理压缩游戏的终极解决方案
  • MonkeyCode从入门到精通:完整使用指南
  • SpringBoot+Vue 农商对接系统管理平台源码【适合毕设/课设/学习】Java+MySQL
  • 3分钟免费激活Windows和Office:KMS_VL_ALL_AIO一键智能激活方案
  • 告别臃肿安装!手把手教你为Zynq-7000定制最小化的Vivado 18.3开发环境
  • 抖音视频无水印解析工具:3步获取纯净版短视频的终极方案
  • 晶振采购实战指南:从参数到供应链,保障电子项目稳定心跳
  • GraphRAG 生产配置:多模型策略怎么选,成本怎么控
  • WzComparerR2技术解析:冒险岛WZ文件逆向工程的完整实现方案