背景
两种最广泛被使用的版本管理工具就是 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、前端面试题库 (面试必备) 推荐:★★★★★
地址:前端面试题库