Git(面试篇)

embedded/2024/12/23 1:19:42/

目录

配置操作

全局配置

当前仓库配置

查看global配置

查看当前仓库配置

删除global配置

删除当前仓库配置

本地操作

查看变更情况

将当前目录及其子目录下所有变更都加入到暂存区

将仓库内所有变更都加入到暂存区

将指定文件添加到暂存区

比较工作区和暂存区的所有差异

比较某文件工作区和暂存区的差异

比较暂存区和HEAD的所有差异

比较某文件工作区和HEAD的差异

创建Commit

将指定工作区文件恢复成暂存区一致

将暂存区指定文件恢复成和HEAD一样

用difftoo比骄傲任意两个commit的差异

查看哪些文件没有给Git管控

将未处理完的变更先保存到stash中

临时任务处理完后继续之前的工作

查看所有stash

取回所有stash

取回某次stash的变更

优雅修改最后一次commit

分支操作

查看当前工作分支及本地分支

查看本地和远端分支

查看远端分支

基于当前分支创建分支

基于指定分支创建新分支

基于某个commit创建分支

创建并切换到该分支

安全删除本地某分支

强行删除本地某分支

删除已合并到master分支的所有本地分支

删除远端origin已不存在的所有本地分支

将A分支合入到当前分支中且未merge创建commit

将A分支合入到B分支中且为merge创建commit

将当前分支基于B分支作rebase,以便将B分支合入到当前分支

将A分支基于B分支做rebase,一边将B分支合入到A分支

变更历史

当前分支各个commit用一行显示

显示就近n个commit

用户图文显示所有分支的历史

查看涉及到某人间变更的所有commit

标签操作

查看已有标签

新建标签

新建带备注标签

给指定的commit打标签

推送一个本地标签

推送全部未推送过的本地标签

删除一个本地标签

删除一个远端标签

远端互交

查看素有远端仓库

添加远端仓库

删除远端仓库

重命名远端仓库

将远端所有分支和标签的变量都拉到本地

把远端分支的变更拉取到本地,且merge到本地分支

将本地分支push到远端


一起加油 ! ! !

配置操作

全局配置

git config --global user.name '你的名字'
git config --global user.email '你的邮箱'

当前仓库配置

git config --local user.name '你的名字'
git config --local user.email '你的邮箱'

查看global配置

git config --global --list

查看当前仓库配置

git config --local --list

删除global配置

git config --unset --global 要删除的配置项

删除当前仓库配置

git config --unset --local 要删除的配置项

本地操作

查看变更情况

git status

将当前目录及其子目录下所有变更都加入到暂存区

git add .

将仓库内所有变更都加入到暂存区

git add -A

将指定文件添加到暂存区

git add 文件1 文件2 文件3

比较工作区和暂存区的所有差异

git diff

比较某文件工作区和暂存区的差异

git diff 文件

比较暂存区和HEAD的所有差异

git diff  --cached

比较某文件工作区和HEAD的差异

git diff HEAD 文件

创建Commit

git commit

将指定工作区文件恢复成暂存区一致

git checkout 文件1 文件2 文件3

将暂存区指定文件恢复成和HEAD一样

git reset 文件1 文件2 文件3

用difftoo比骄傲任意两个commit的差异

git difftool 提交1 提交2

查看哪些文件没有给Git管控

git ls-files -others

将未处理完的变更先保存到stash中

git stash

临时任务处理完后继续之前的工作

pop 不保留 stash

apply 保留 stash

git stash pop 
git stash apply

查看所有stash

git stash list

取回所有stash

git stash list

取回某次stash的变更

git stash pop stash @{}

优雅修改最后一次commit

git add
git commit --amend

分支操作

查看当前工作分支及本地分支

git branch -v

查看本地和远端分支

git branch -av

查看远端分支

git branch -rv

基于当前分支创建分支

git branch 新分支

基于指定分支创建新分支

git branch 新分支 指定分支

基于某个commit创建分支

git branch 新分支 某个 commit的id

创建并切换到该分支

git checkout -b 新分支

安全删除本地某分支

git branch -d

强行删除本地某分支

git branch -D 要删除的分支

删除已合并到master分支的所有本地分支

git branch --merged master | grep -v '^\*\| master \' xargs -n 1 git brach -d

删除远端origin已不存在的所有本地分支

git remote prune orign

将A分支合入到当前分支中且未merge创建commit

git merge A分支

将A分支合入到B分支中且为merge创建commit

git merge A分支 B分支

将当前分支基于B分支作rebase,以便将B分支合入到当前分支

git rebase B分支

将A分支基于B分支做rebase,一边将B分支合入到A分支

git rebase B分支 A分支

变更历史

当前分支各个commit用一行显示

git log --oneline

显示就近n个commit

git log -n

用户图文显示所有分支的历史

git log --oneline --graph --all

查看涉及到某人间变更的所有commit

git log 文件

某文件各行最后对应的commit以及作者

git blame 文件

标签操作

查看已有标签

git tag

新建标签

git tag v1.0

新建带备注标签

git tag -a v1.1 commitid

给指定的commit打标签

git tag v1.0 commitid

推送一个本地标签

git push origin v1.0

推送全部未推送过的本地标签

git push origin --tags

删除一个本地标签

git tag -d v1.0

删除一个远端标签

git push oring :refs/tags/v1.0

远端互交

查看素有远端仓库

git remote -v

添加远端仓库

git remote remove remote的名称

删除远端仓库

git remote remove remote的名称

重命名远端仓库

git remote rename 旧名称 新名称

将远端所有分支和标签的变量都拉到本地

git fetch remote

把远端分支的变更拉取到本地,且merge到本地分支

git push origin 分支

将本地分支push到远端

git push origin 分支名


http://www.ppmy.cn/embedded/100466.html

相关文章

云计算实训32——roles基本用法、使用剧本安装nginx、使用roles实现lnmp

一、安装nginx并更改其端口 编辑hosts配置文件 [rootmo ~]# vim /etc/ansible/hosts 创建目录 [rootmo ~]# mkdir /etc/ansible/playbook 编辑配置文件 [rootmo ~]# vim /etc/ansible/playbook/nginx.yml 执行测试 [rootmo ~]# ansible-playbook /etc/ansible/playbook/n…

YoloV8改进策略:卷积篇|ACConv2d模块在YoloV8中的创新应用与显著性能提升|简单易用|即插即用

摘要 在本文中,我们创新性地将ACConv2d模块引入到YoloV8目标检测模型中,通过对YoloV8中原有的Conv卷积层进行替换,实现了模型性能的大幅提升。ACConv2d模块基于不对称卷积块(ACB)的设计思想,利用1D非对称卷积(13和31卷积)来增强标准方形卷积核(如33卷积)的表征能力。…

二进制协议集合

二进制协议在网络通信中通常用于提高数据传输的效率和速度,相比于文本协议(如 HTTP 的 JSON 或 XML),二进制协议的数据格式更为紧凑,解析和处理速度更快。以下是一些常见的二进制协议: 1. Protocol Buffer…

C语言-有两个磁盘文件A和B,各存放一行字母,今要求把这两个文件的信息合并(按字母顺序排列),输出到一个新文件C中去-深度代码解析

1、题目要求 有两个磁盘文件A和B,各存放一行字母,今要求把这两个文件的信息合并(按字母顺序排列),输出到一个新文件C中去 2、准备工作 问题1:为什么不需要手动创建C.txt文件? 答:根…

基础算法--高精度数据(2)

本节继续上节内容:高精度数据处理。本节主题是回文数。 一、判断方法 什么是回文数:一个数字从左往右读与从右往左读是一样的,那么这个数就是回文数。例如:121,6226,3333、12121等。简单的判断回文数的方…

Mysql 报错 1365 - Division by 0

Mysql 报错 1365 - Division by 0 解决办法 直接运行一下命令 set sql_mode(select REPLACE(sql_mode,ERROR_FOR_DIVISION_BY_ZERO,));

【Electron】桌面应用开发启动直接打开一个网址或者浏览器打开一个网址

【Electron】桌面应用开发启动时直接打开一个网址或者跳转浏览器打开一个网址 前一篇有写过 Electron 桌面应用开发快速入门到打包Windows应用程序 但是现在需要程序打开的时候直接打开一个链接,在程序的窗口打开或者直接跳转浏览器打开 一、启动时直接打开一个网…

AgentQ,超越人类的人工智能代理

MultiOn 宣布推出一款新代理AgentQ,这是一款令人惊叹的产品,它整合了我最近一直在讨论的大部分内容:将 LLM 与搜索相结合。 但这个经纪人很特殊。 与其他代理不同的是,由于巧妙地使用了对齐技术,该代理可以从好的和坏的…