GIT 常用命令

文章目录

新人 git 常用命令

本文整理了 git常用的一些命令,主要参考了廖雪峰的Git教程,强烈建议有条件的小伙伴可以认真学习廖雪峰Git教程

初始化 git 仓库

bash 复制代码
git init

创建文件添加 git

bash 复制代码
git add 文件名  --添加对应的文件
git add .  --添加所有的修改文件

提交 git 文件修改

bash 复制代码
git commit -m "提交的备注信息"  --提交所有添加的文件

查看 git 当前状态

bash 复制代码
git status

查看 git 提交信息

bash 复制代码
git log  --查看所有信息
git log --pretty=oneline  --查看的信息汇总到一行

git log 可带参数很多,例如 --graph --pretty=oneline --abbrev-commit


查看尚未提交的修改

bash 复制代码
git diff

查看已经提交的修改内容

bash 复制代码
git diff [commit id]

查看文件更改(当前工作区和最新提交版本库的区别)

bash 复制代码
git diff HEAD -- [文件名]

版本回退

bash 复制代码
git reset --hard HEAD^  --回退到上一个版本
git reset --hard HEAD~100  --回退到 100 个版本前
git reset --hard [指定的 commit id]  --返回到指定的提交版本,可以是以前的,也可以是以后的

查看所有执行的 git 命令

bash 复制代码
git reflog

可以以此确定当前所在的 commit id 和以前所处的 commit id

取消暂存区的改动,重新放回工作区

bash 复制代码
git restore --staged [文件名]

丢弃工作区的改动

bash 复制代码
git restore [文件名]


全部撤销工作区的改动,也可以使用 checkout

bash 复制代码
git checkout -- [文件名]

命令中 -- 很重要,没有加 -- ,就变成了切换到同名的分支

将暂存区的改动文件重新放回工作区也可以使用reset

bash 复制代码
git reset HEAD [文件名]

恢复工作区误删除的文件

bash 复制代码
git restore <文件名>
git checkout -- <文件名>  //删错了,但是版本库里还有,可以使用 checkout

确定提交删除操作

bash 复制代码
git add/rm <文件名>
git commit -m "删除信息"

向远程仓库推送代码

bash 复制代码
git push <远程库名称> <分支名>
git push -u origin <分支名>  

第一次向远程仓库推送分支内容,加入-u 参数,不仅会推送本地分支内容,还会把本地分支和远程分支关联起来,在以后的推送中可以简化命令 git push origin <分知名> ,默认的远程库名称为 origin,也可以自定义,例如一个本地仓库同时关联 gitee 和 github:

bash 复制代码
git remote add github git@github.com:<github远程注册名>/<远程仓库名>.git
git remote add gitee git@gitee.com:<gitee远程注册名>/<远程仓库名>.git
git remote -v
gitee	git@gitee.com:<gitee远程注册名>/<远程仓库名>.git (fetch)
gitee	git@gitee.com:<gitee远程注册名>/<远程仓库名>.git (push)
github	git@github.com:<github远程注册名>/<远程仓库名>.git (fetch)
github	git@github.com:<github远程注册名>/<远程仓库名>.git (push)

git push github master  //推送 GitHub master
git push gitee master  // 推送 gitee master

查看远程库信息

bash 复制代码
git remote
git remote -v

删除远程库

bash 复制代码
git remote rm <名称>
git remote rm origin  //删除本地和远程 origin 的关联

这里删除的是本地库和远程库的绑定联系,并非真正删除远程库的内容,如确实需要远程删除,需要手动登录 GitHub 或者 Gitee,找到仓库,手动删除。

关联远程仓库

bash 复制代码
git remote add origin git@server-name:path/repo-name.git

关联一个远程库时必须给远程库指定一个名字,origin是默认习惯命名

从 git 远程仓库克隆

bash 复制代码
git clone <远程仓库地址>

git查看当前所有分支信息

bash 复制代码
git branch

git创建分支

bash 复制代码
git branch <分支名>

git切换分支

bash 复制代码
git checkout <分支名>
git switch <分支名>

创建+切换

bash 复制代码
git checkout -b <分支名>
git switch -c <分支名>

合并分支(合并指定分支到当前分支)

bash 复制代码
git merge <分支名>

删除分支

bash 复制代码
git branch -d <分支名>
git branch -D <分支名>  //强行删除

git终止当前合并操作

bash 复制代码
git merge --abort

合并过程中不能切换分支

合并代码时强制禁用 Fast Forward

不使用 fast forward 会产生一个新的提交,所以加参数-m 表明提交信息

bash 复制代码
git merge --no-ff -m "提交信息" <分支名>

stash暂存当前分支内容

bash 复制代码
git stash

查看stash暂存区 列表

bash 复制代码
git stash list

恢复工作区内容

bash 复制代码
git stash pop  //恢复工作区内容并删除列表
git stash apply  //恢复工作区内容,但是列表记录还在
git stash drop //删除 stash list 列表内容
git stash apply stash@{0}  //如果 stash 列表中不止一个暂存,stash@{}中可选择恢复哪一个stash

合并特定的提交到当前的分支

bash 复制代码
git cherry-pick <commit id>

指定本地分支与远程分支的关联(以 dev 分支为例)

bash 复制代码
git branch --set-upstream-to=origin/dev dev
git branch --set-upstream-to <branch-name> origin/<branch-name>

拉取分支

bash 复制代码
git pull

在本地创建和远程关联的分支

bash 复制代码
git checkout -b branch-name origin/branch-name

rebase把本地未push的分叉提交历史整理成直线

bash 复制代码
git rebase

rebase前

rebase 后

解决当前索引的冲突

当 git进行 rebase 操作后,卡在正在变基阶段,切换分支提示需要先解决当前的索引冲突 you need to resolve your current index first,解决方法

bash 复制代码
git reset --merge

Git中打标签

git 的标签其实对应的是某次提交的 commit id

bash 复制代码
git tag <标签名>
git tag v1.0

git默认标签打在最新 commit 的 id 上,如要指定某次 commit,可以指定 id

bash 复制代码
git tag <tag name> <commit id>
git tag v0.9 3165663

还可以有其他参数,创建带有说明的标签,用-a指定标签名,-m指定说明文字

bash 复制代码
git tag -a <tag name> -m "tag messsage" <commit id>
git tag -a v1.0 -m "version 1.0 released" 3165663

查看tag

bash 复制代码
git tag

查看 tag 具体信息

bash 复制代码
git show <tag name>
git show v1.0

删除标签

bash 复制代码
git tag -d <tag name>

推送某个标签到远程

bash 复制代码
git push origin <tag name>

一次推送所有没有推送的本地标签

bash 复制代码
git push origin --tags

删除远程标签

bash 复制代码
git push origin :refs/tags/<tag name>

配置别名alias

--global 表示全局变量,如果不加,那只针对当前的仓库起作用。

repo 等级的配置一般在.git/config 下,global 等级的一般在~/.gitconfig 或者 ~/.config/git/config下

bash 复制代码
git config --global alias.st status  //git st就表示git status
git config --global alias.co checkout  //co表示checkout
git config --global alias.ci commit  //ci表示commit
git config --global alias.br branch  //br表示branch
git config --global alias.lg "log --color --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit"
相关推荐
虾球xz5 分钟前
游戏引擎学习第11天
stm32·学习·游戏引擎
心怀梦想的咸鱼7 分钟前
Ue5 umg学习(三)文本控件
学习·ue5
心怀梦想的咸鱼9 分钟前
Ue5 umg学习(二)图像控件,锚点
学习·ue5
aPurpleBerry44 分钟前
【问题解决】Github上手动Delete file之后, git remote add+git push出错
git·github
小A1591 小时前
STM32完全学习——系统时钟设置
stm32·嵌入式硬件·学习
2301_775281191 小时前
柯桥生活英语口语学习“面坨了”英语怎么表达?
学习·生活
江梦寻1 小时前
思科模拟器路由器配置实验
开发语言·网络·网络协议·学习·计算机网络
一只特立独行的程序猿2 小时前
关于GCC内联汇编(也可以叫内嵌汇编)的简单学习
汇编·学习·gcc
虾球xz2 小时前
游戏引擎学习第10天
学习·游戏引擎
Chef_Chen2 小时前
从0开始学习机器学习--Day25--SVM作业
学习·机器学习·支持向量机