20个常用的 Git 指令用法

简介: 20个常用的 Git 指令用法

背景

两种最广泛被使用的版本管理工具就是 Git 和 svn,而 Git 优越的版本管理能力,及广被使用的 github、gitlab 开源平台,Git 成为了程序员必须掌握了一个工具。

大家都很熟练的使用着 vscode 等一些可视化工具来操作 Git,对 Git 的很多指令都不甚了解。

殊不知,可视化工具的底层就是 Git 的各个指令,当我们熟悉了 Git 指令的各种写法,将更理解在可视化工具中用到的功能的底层指令。

Git 工作流程

Git 分为 4 个工作区:

  • 工作区:指在本地仓库中的全部代码区域;
  • 暂存区:指在本地仓库中通过 git add 后的代码区域;
  • 本地仓库:指在本地仓库中的 git commit 后的代码区域;
  • 远程仓库:远程仓库指的托管代码的服务器。

常用指令

git clone

git clone 命令用于将存储库克隆到本地。

git clone [url] // 将存储库克隆到本地
复制代码

git init

git init 命令用于在目录中创建新的 Git 仓库。

- git init // 创建新的 Git 仓库,在当前路径下生成 .git 目录
复制代码

git remote

git remote 用于管理跟踪远程仓库。

git remote -v // 查看连接的远程仓库地址
git remote add origin [gitUrl] // 为本地仓库添加远程仓库地址
git push -u origin master // 将本地仓库的master和远程仓库的master进行关联
git remote origin set-url [gitUrl] // 为本地仓库修改远程仓库地址
git remote rm origin // 为本地仓库删除远程仓库连接
复制代码

git checkout

git checkout 命令用于切换分支

git checkout [branchName] // 切换分支
git checkout -b [branchName] // 新建分支并切换到该分支
复制代码

git branch

git branch 命令用于查看、创建、删除分支。

git branch //查看本地分支
git branch -r //查看远程分支
git branch -a //查看本地和远程分支
git branch [branchName] //新建本地分支但不切换
git branch -D [branchName] //删除本地分支
git branch -m [oldBranchName] [newBranchName] //重新命名分支
复制代码

git tag

git tag 用于创建、删除、查看标签。

git tag [tagName] // 新建标签
git tag // 查看标签列表
git tag -d [tagName] // 删除标签
git push origin [tagName] // 推送标签到远程仓库
复制代码

git add

git add 命令用于将本地文件添加到暂存区。

git add [file1] [file2] // 添加指定文件至暂存区
git add [dir] // 添加指定目录至暂存区
git add . // 添加当前目录下所有文件至暂存区
git add -A // 添加当前仓库下的所有文件改动至暂存区
复制代码

git commit

git commit 命令用于将暂存区内容添加到本地仓库中。

git commit -m 'xxx' // 将暂存区文件添加到本地仓库,并记录下备注
git commit -am 'xxx' // 将文件添加到暂存区,再添加到本地仓库,并记录下备注
复制代码

git push

git push 命令用于将本地分支推送到远程仓库。

git push [remoteName] [branchName] // 推送分支
git push --set-upstream [remoteName] [branchName] // 推送分支并建立关联关系
复制代码

git pull

git pull 命令用于从远程仓库拉取代码并合并到本地当前分支。

git pull // 从远程仓库拉取代码合并到本地,等同于 git fetch && git merge
git pull --rebase // 使用rebase的模式进行合并
复制代码

git fetch

git fetch 命令用于从远程获取代码库。

git fetch // 从所有远程仓库拉取当前分支代码
git fetch [remoteName] // 从指定远程仓库拉取当前分支代码
git fetch --all // 获取所有远程仓库所有分支的更新
复制代码

git cherry-pick

git cherry-pick 命令用于获取指定的 commit,可以将分支 a 上的 commit 1,复制到分支 b上。

git cherry-pick [commitId] // 获取指定的commit
复制代码

git merge

git merge 命令用于分支合并,将其他分支的内容合并到当前分支中。

git merge [branchName]
复制代码

git rebase

git rebase 用于分支变基。

git rebase master // 将当前分支变基到 master 分支上
复制代码

git rebase -i 交互模式:

git rebase -i [commitId] // 基于 commitId 进行 rebase,交互式变基,可以重新编辑 commit,比如压缩合并
复制代码

git reset

git reset 命令用于回退版本,可以指定退回某一次提交的版本。

git reset HEAD^ // 回退所有内容到上一个版本
git reset HEAD^ [filename] // 回退某文件到上一个版本
git reset [commitId] // 回退所有内容到指定版本
git reset --soft HEAD~1 // 回退本地仓库到上一个版本
git reset --hard HEAD~1 // 回退本地仓库到上一个版本,并删除工作区所有未提交的修改内容
复制代码

git revert

git revert 指令用于回滚提交,可以回滚某一次提交记录。

git revert [commitId] // 回滚某次提交
git revert [commitId] -m 1 // 回滚某次 merge 的 commit,1 代表保留主分支代码
复制代码

git stash

git stash 用于暂存文件。

git stash // 暂存文件
git stash save 'aa' // 暂存文件,添加备注
git stash pop // 应用最近一次暂存文件,并删除暂存记录
git stash apply // 应用某个暂存,但不删除该暂存记录
git stash list // 暂存记录
git stash clear // 删除所有暂存记录
复制代码

git reflog

git reflog 记录了所有的 commit 操作记录,便于错误操作后找回。

git reflog
复制代码

git rm

git rm 用于从 git 仓库删除指定文件或目录。

git rm [filname]
git rm [dir]

 

总结给大家一个实用面试题库

1、前端面试题库 (面试必备)            推荐:★★★★★

地址:前端面试题库

相关文章
|
6月前
|
缓存 开发工具 git
git最实用指令
git最实用指令
27 1
|
7月前
|
人工智能 数据可视化 开发工具
Git log 进阶用法(含格式化、以及数据过滤)
Git log 进阶用法(含格式化、以及数据过滤)
|
7月前
|
开发工具 git
常用的git指令
常用的git指令
77 0
|
7月前
|
安全 开发工具 git
三分钟学完Git版本控制常用指令
Git本地有三个工作区域:工作目录(Working Directory)、暂存区(Stage/Index)、资源库(Repository或Git Directory)。如果在加上远程的git仓库(Remote Directory)就可以分为四个工作区域。文件在这四个区域之间的转换关系如下:
58 0
三分钟学完Git版本控制常用指令
|
7月前
|
Java Shell 开发工具
Git快速入门+常用指令
Git快速入门+常用指令
67 0
|
7月前
|
Shell 开发工具 git
Git获取本地仓库及基础操作指令
Git获取本地仓库及基础操作指令
86 0
|
3月前
|
安全 网络安全 开发工具
深入探索Git:全面解析Git的用法与最佳实践
深入探索Git:全面解析Git的用法与最佳实践
76 2
|
6月前
|
开发工具 git
git常用指令 , 配置git仓库
git常用指令 , 配置git仓库
|
6月前
|
开发工具 git
git如何为常用指令创建文件夹,.bashrc如何配置文件
git如何为常用指令创建文件夹,.bashrc如何配置文件
|
6月前
|
网络安全 开发工具 git
idea如何使用git指令
idea如何使用git指令