Git基础之基本操作

文件的四种状态

Untracked:未追踪,如新建的文件,在文件夹中,没有添加到git库,不参与版本控制,通过git add将状态变为staged

Unmodify:文件已入库,未修改,即版本库中的文件快照内容与文件夹完全一致,这种类型的文件有两种去处,如果被修改,变为Modified,如果使用git rm移除版本库,则称为Untracked文件

Midified:文件已修改,仅仅只是被修改,没有对其进行其他操作,也有几个去处,

1.通过git add可进入staged状态

2.使用git checkout,则丢弃修改过,返回到unmodify状态,

3.git checkout取出文件,覆盖当前修改

Staged:暂存状态,执行git commint 将修改同步到库中,此时库中文件与本地文件又变为一致,文件为Unmodify状态,使用git reset HEAD filename取消暂存,文件状态为Modified

git status 查看相关文件的状态

git add . 将所有文件添加到暂存区

git commint -m 提交暂存区的内容到本地仓库 -m就是提交信息

如果我们新建一个git项目,此时里面就一个.git文件夹,此时运行

git status

如果此时我们新建一个hello.txt的文件,再运行git status,告诉我们此时有一个hello.txt没有被跟踪

此时我们执行git add .将其添加到暂存区之后再执行git status,告诉我们此时有一个变为了待提交的状态,暂存区有文件了

我们将其提交到本地仓库

此时再运行git status,此时就没有东西了


忽略文件

有些时候,我们不希望把某些文件纳入版本控制中,比如数据库文件、临时文件、设计文件等

在主目录下建立"gitignore"文件,此文件有如下规则

1.忽略文件中的空行或是以井号#开始的行将会被忽略

2.可以使用Linux通配符。例如:星号(*)代表任意多个字符,问好(?)代表一个字符,方括号[ ]代表可选字符范围,大括号{String1,String2}代表可选字符串

3.如果名称的最前面有一个感叹号!,标识例外规则,不被忽视

4.如果名称的最前面有一个路径分隔符/,表示要忽略的文件在此目录下,而子目录的文件不用忽略

5.如果名称的最后面是一个路径分隔符/,表示要忽略的是此目录下该名称的子目录,而非文件

#为注解

*.txt 忽略所有以.txt结尾的文件,这样

!lib.txt 但lib.txt除外

/temp 忽略其更根目录

bulid/ 忽略bulid一下所有文件

doc/*.txt 会忽略doc/notes.txt,但是不会忽略doc/server/arch.txt

相关推荐
我会一直在的2 小时前
Devps持续集成
git·ci/cd
CoderJia程序员甲3 小时前
GitHub 热榜项目 - 日榜(2026-02-08)
git·ai·开源·llm·github
Serene_Dream5 小时前
git 常用命令
git
jiayong235 小时前
Detached HEAD 状态详解
git
李少兄14 小时前
在 IntelliJ IDEA 中修改 Git 远程仓库地址
java·git·intellij-idea
先跑起来再说20 小时前
Git 入门到实战:一篇搞懂安装、命令、远程仓库与 IDEA 集成
ide·git·后端·elasticsearch·golang·intellij-idea
承渊政道1 天前
Linux系统学习【Linux系统的进度条实现、版本控制器git和调试器gdb介绍】
linux·开发语言·笔记·git·学习·gitee
Doro再努力1 天前
【Linux操作系统12】Git版本控制与GDB调试:从入门到实践
linux·运维·服务器·git·vim
摇滚侠1 天前
MAC IDEA GIT 提交区显示了几个不存在的目录
git·idea
城东1 天前
Git使用[远程仓库远端的head比本地和提交的head旧,其他人拉不到最新代码]
git·head·远程仓库远端·比本地和提交的head旧·其他人拉不到最新代码