git用法总结

以gitee为例,GitHub也可参考本文

创建远程仓库

在自己的gitee主页

创建本地仓库

在文件夹下,右键→git bash here

bash 复制代码
git init

添加gitignore

bash 复制代码
vi .gitignore

gitignore里的内容根据自己实际情况设置,这里举个例子

bash 复制代码
# #开头的是注释
# Prerequisites
*.d # *是通配符

# Compiled Object files
*.slo
*.lo
*.o
*.obj

# Precompiled Headers
*.gch
*.pch

# Compiled Dynamic libraries
*.so
*.dylib
*.dll

# Fortran module files
*.mod
*.smod

# Compiled Static libraries
*.lai
*.la
*.a
*.lib

# Executables
*.exe
*.out
*.app

#下面这个写法是整个文件夹添加到gitignore里
build/
.vscode/

链接远程仓库

bash 复制代码
git remote add origin https://
# 或者
git remote add origin git@
bash 复制代码
git add .
git commit -m "first commit"
git push origin master

拉一个自己的分支

基于master分支拉一个自己的开发分支

在master分支下

bash 复制代码
git branch dev
git checkout dev

编辑以后,git status看一下改动,git add git commit -m "balabala"

在dev分支下,push到远程对应的仓库

bash 复制代码
git push origin dev:dev

合并master的更新到自己的分支

确保本地 master 分支与远程 origin 的 master 分支同步

注意这一步不能在master分支下进行

bash 复制代码
git fetch origin master:master

这会将 origin 的 master 分支拉取到本地 master 分支,如果本地尚未存在 master 分支,则会创建一个。

将本地 master 分支合并到本地 dev 分支

切换到dev分支

bash 复制代码
git merge master

推送到远程的dev分支

在dev分支下

bash 复制代码
git push origin dev:dev

手动解决冲突

编辑冲突文件,查找 <<<<<<、====== 和 >>>>>> 标记的区域并手动解决冲突。保存更改。

添加解决冲突过程中涉及的文件

bash 复制代码
git status
git add <conflict_file>
git commit -m "Resolve merge conflicts"

提pull request 将自己的开发分支合并到master分支

再提pr之前要先解决冲突

就是将master 的更新先合并到自己的分支里

没有冲突一般很好提pr

管理员审核测试通过即可合并

删除远程仓库

bash 复制代码
git remote remove origin

直接拉现成的远程仓库

bash 复制代码
git clone git@balabala

git rm 删除的用法详解

git分区介绍

Git 本地数据管理,大概可以分为三个区:

工作区(Working Directory):是可以直接编辑的地方。

暂存区(Stage/Index):数据暂时存放的区域(commit后)。

版本库(commit History):存放已经提交的数据(push后的)。

工作区的文件 git add 后到暂存区,暂存区的文件 git commit 后到版本库

rm / rm -r

删除工作区和版本库的文件

bash 复制代码
rm 文件
rm -r 文件夹

git rm / git rm -r

作用: 删除工作区文件,并且将这次删除放入暂存区。

注意: 要删除的文件是没有修改过的,就是说和当前版本库文件的内容相同。

结果: 删除了工作区和版本库的文件,因为暂存区不可能有该文件(如果有意味着该文件修改后 git add 到暂存区,那样 git rm 命令会报错)

bash 复制代码
git rm 文件
git rm -r 文件夹

git rm -f / git rm -f -r

作用: 删除工作区和暂存区文件,并且将这次删除放入暂存区。

注意: 要删除的文件已经修改过,就是说和当前版本库文件的内容不同。

结果: 删除了工作区、暂存区和版本库的文件

bash 复制代码
git rm -f 文件
git rm -f -r 文件夹

git rm --cached / git rm --cached -r

作用: 删除暂存区文件,但保留工作区的文件,并且将这次删除放入暂存区。

结果: 删除了暂存区和版本库的文件,但保留了工作区的文件。如果文件有修改并 git add 到暂存区,再执行 git rm --cached 和 git commit,那么保留的工作区文件是修改后的文件,同时暂存区的修改文件和版本库的文件也被删了。

然后commit最后在push

bash 复制代码
git rm --cached 文件
git rm -r --cached 文件夹

删除分支

删除本地分支

注意这个操作必须在另一个不想删除的分支下进行

bash 复制代码
git branch -d 分支名
相关推荐
Selicens4 小时前
git批量删除本地多余分支
前端·git·后端
闲云一鹤1 天前
Git LFS 扫盲教程 - 你不会还在用 Git 管理大文件吧?
前端·git·前端工程化
vibecoding日记4 天前
为什么我就想要「线性历史 + Signed Commits」,GitHub 却把我当猴耍 🤬🎙️
git·编程工具
程序员小崔日记4 天前
如何将代码轻松上传到 Gitee?Git 使用全攻略!
git·gitee·上传
Bigger5 天前
为什么你的 Git 提交需要签名?—— Git Commit Signing 完全指南
git·开源·github
DianSan_ERP6 天前
电商API接口全链路监控:构建坚不可摧的线上运维防线
大数据·运维·网络·人工智能·git·servlet
红豆子不相思6 天前
Tomcat 环境搭建与集群实战
服务器·git·tomcat
杰哥技术分享6 天前
Git 仓库迁移技术文档:从 CODING.net 迁移至腾讯云 CNB
git
梅孔立6 天前
Ansible 100 台服务器一键管控实战 进阶版
服务器·git·ansible