git基础概念和常用命令(日常开发收藏备用)

目录

### 常用命令

### 远程仓库与克隆

### 分支管理

### 子模块(Submodule)

### 其他高级操作

### 交互式暂存(Interactive Staging)

### cherry-pick

### rebase

### reflog与reset

### 子树合并(Subtree Merge)

### 配置别名


Git是一个分布式版本控制系统,用于跟踪和管理代码的更改历史。在团队开发中,Git能够帮助开发者协同工作、分支管理、合并代码变更,并轻松回滚到任何提交点。以下是一些基本概念和常用命令的详解:

###基本概念
1. **仓库(Repository)**:存储所有项目文件及版本历史的地方。
2. **工作目录(Working Directory)**:开发者日常编辑代码的工作区。
3. **暂存区(Staging Area/Index)**:一个临时区域,用于保存准备提交到下一次提交中的改动。
4. **提交(Commit)**:一个提交代表了项目的一次快照,包含了相关修改信息以及一个唯一的哈希值标识。
5. **分支(Branch)**:允许在同一份代码库上并行开发不同功能或修复。每个分支都有自己的提交历史,可以随时合并回主分支或其他分支。

### 常用命令

- 初始化仓库:
  ```sh
  git init
  ```
  创建一个新的本地Git仓库。

- 配置Git:
  ```sh
  git config --global user.name "Your Name"
  git config --global user.email you@example.com
  ```
  设置全局用户名称和邮箱。

- 添加文件到暂存区:
  ```sh
  git add <file>
  ```
  或 `git add .` 以添加当前目录下的所有已修改或新文件。

- 提交暂存区的改动到仓库:
  ```sh
  git commit -m "Commit message describing changes"
  ```
  将暂存区的所有改动记录为一个新提交。

- 推送本地分支到远程仓库:
  ```sh
  git push origin <branch-name>
  ```
  将本地指定分支推送到名为origin的远程仓库。

- 创建与切换分支:
  ```sh
  git branch <new-branch-name>    # 创建分支
  git checkout <branch-name>      # 切换分支
  git checkout -b <new-branch>   # 创建并切换到新的分支
  ```

- 合并分支:
  ```sh
  git merge <branch-to-merge>     # 将指定分支合并到当前分支
  ```

- 删除分支:
  ```sh
  git branch -d <branch-to-delete>  # 删除已合并过的分支
  git branch -D <branch-to-delete>  # 强制删除未合并的分支
  ```

- 查看状态:
  ```sh
  git status                      # 显示当前工作目录的状态,包括哪些文件已修改、暂存等
  ```

- 撤销操作:
  ```sh
  git reset --hard HEAD~1         # 回退到上一个提交,会丢弃未提交的改动
  ```

这只是Git的基本操作集合,实际使用中还有许多更高级的操作,例如解决冲突、stash暂存改动、cherry-pick挑选特定提交应用到其他分支等。对于大型项目和团队协作来说,熟练掌握Git是必不可少的技能。

当然,Git的功能非常丰富,这里进一步详解一些关键概念和高级操作:

### 远程仓库与克隆

1. **远程仓库**:一个中心化的存储库,用于团队成员之间共享代码。比如GitHub、GitLab或自建的Git服务器。

   - 添加远程仓库:
     ```sh
     git remote add origin https://github.com/username/repo.git
     ```

   - 从远程仓库克隆项目到本地:
     ```sh
     git clone https://github.com/username/repo.git
     ```

2. **拉取(Pull)与推送(Push)**:
   - 从远程仓库获取最新提交并合并到本地分支:
     ```sh
     git pull origin <branch-name>
     ```
   - 将本地分支推送到远程仓库:
     ```sh
     git push origin <branch-name>
     ```

### 分支管理

- **查看所有分支**:
  ```sh
  git branch
  ```

- **合并冲突**:当两个分支对同一文件的同一部分进行了不同的修改,合并时会出现冲突。需要手动编辑冲突文件解决冲突,然后提交。

- **fetch与merge的区别**:`git fetch` 只是从远程仓库下载最新的数据到本地,但不会自动合并;而 `git pull` 则是 `fetch` 和 `merge` 的组合,它会将远程分支的更新直接合并到当前分支。

### 标签(Tag)

- **创建标签**:为了标记特定的提交(如版本发布),可以创建标签。
   ```sh
   git tag v1.0 <commit-hash>    # 给指定提交打标签
   git tag v1.0                 # 给当前HEAD指针指向的提交打标签
   ```

- **推送标签到远程仓库**:
   ```sh
   git push origin --tags
   ```

### 子模块(Submodule)

- **添加子模块**:在项目中嵌入另一个Git仓库作为子模块。
   ```sh
   git submodule add https://github.com/submodule-repo submodule-dir
   ```

-**更新子模块**
   ```sh
   git submodule update --remote
   ```

### 其他高级操作

- **暂存单个文件的部分改动**:通过 `git add -p` 或 `git add --patch` 进行交互式暂存。

- **stash功能**:临时保存工作区未提交的改动,以便切换分支或者清理工作区。
   ```sh
   git stash          # 暂存改动
   git stash list     # 查看stash列表
   git stash apply    # 应用stash中的改动
   git stash drop     # 删除stash中的某个或全部改动
   ```

- **重置与撤销**:除了上面提到的回退到上一次提交外,还可以使用 `git reset` 更精细地控制版本历史,例如硬重置、混合重置等。

以上内容仅为Git功能的一部分,实际使用中还有很多其他技巧和策略可以根据团队协作需求进行应用。

当然,以下是Git中更详细的几个高级概念和操作:

### 交互式暂存(Interactive Staging)

- 使用 `git add -p` 或 `git add --patch` 可以逐行或者逐块地选择性地将改动添加到暂存区。它会打开一个交互式的界面,询问你对每一部分改动如何处理(Stage this hunk、Discard this hunk等)。

### cherry-pick

- **cherry-pick**:用于从其他分支复制一个提交并应用到当前分支。
   ```sh
   git cherry-pick <commit-hash>
   ```
   这在需要获取特定提交的修复或特性时非常有用。

### rebase

- **rebase**:不同于合并,rebase是将一个分支的更改应用于另一个分支顶部的过程,从而创建一个新的线性历史。这通常使得项目的历史记录更加清晰。
   ```sh
   git checkout feature-branch
   git rebase master
   ```
   上述命令将会把feature-branch分支的所有提交重新应用到master分支的最新提交上。

### reflog与reset

- **reflog**:记录了HEAD指针的所有移动,包括切换分支、提交和回退操作。当需要找回因为误操作而丢失的提交时,可以参考reflog。
   ```sh
   git reflog
   ```

- **reset**:有多种模式,如`--soft`、`--mixed`(默认)、`--hard`。例如:
   ```sh
   git reset --hard HEAD~3    # 回滚到前3个提交,并丢弃所有未提交的改动
   git reset <commit-hash>     # 将HEAD指向指定提交,混合模式下工作目录也会恢复至该提交状态
   git reset --soft HEAD~1    # 回滚到前一个提交,但保留未提交的改动在工作目录中
   ```

### 子树合并(Subtree Merge)

- 当一个项目的子目录对应的是一个独立的Git仓库时,可以使用子树合并策略来管理这种关系。
   ```sh
   git subtree add --prefix=subdir https://github.com/external-repo.git master
   git subtree pull --prefix=subdir https://github.com/external-repo.git master
   ```

### 配置别名

- 为了简化常用命令,可以在Git配置文件中设置别名。
   ```sh
   git config --global alias.co checkout
   git config --global alias.br branch
   ```

以上内容仅为Git功能的一部分,实际使用中还有很多其他的工具和技术可以根据团队协作需求进行定制和优化。熟练掌握这些命令和概念可以帮助开发者更高效地使用Git进行版本控制和代码协同开发。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/280668.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Linux操作系统( YUM软件仓库技术 )

镜像文件的回环挂载&#xff08;把iso镜像文件释放成系统安装光盘&#xff09;foundation0上操作 回环挂载的用法&#xff1a; du -sh 对象名 //估算文件&#xff08;一切对象皆文件&#xff09;大小 !$ //上一条命令的最后一个参数 新创建的挂载点目录是空白目录 挂载&#xf…

【OpenCV】OpenCV 4.9.0 正式发布

​ 开源计算机视觉库 OpenCV 4.9.0 已于2023年12月29日正式发布。 此次发布有DNN模块对ONNX Attention、Einsum等层的支持、新的fastGEMM实现、transformers的实验性支持等诸多亮点。 OpenCV 4.9.0 更新内容&#xff1a; &#xff08;来自OpenCV中国团队以及中国社区的贡献…

【Web】vulhub-httpd apache解析漏洞复现(1)

目录 ①CVE-2017-15715 ②apache_parsing_vulnerability ①CVE-2017-15715 贴出源码&#xff1a; <?php if(isset($_FILES[file])) {$name basename($_POST[name]);$ext pathinfo($name,PATHINFO_EXTENSION);if(in_array($ext, [php, php3, php4, php5, phtml, pht]))…

Linux:apache优化(4)—— 隐藏版本号

运行环境 yum -y install apr apr-devel cyrus-sasl-devel expat-devel libdb-devel openldap-devel apr-util-devel apr-util pcre-devel pcre gcc make zlib-devel 源码包配置 ./configure --prefix/usr/local/httpd --enable-cgi --enable-rewrite --enable-so --enabl…

cleanmymac这个软件怎么样?值不值得下载

cleanmymac是我必装的mac端清理软件&#xff0c;界面简洁好看&#xff0c;完美适配mac系统&#xff0c;文件清理的速度、精度都比较优秀&#xff0c;还是比较不错的呢。cleanmymac作为一款第三方清洁应用程序&#xff0c;具有专业完整的清理功能&#xff0c;包括释放内存、一键…

【办公技巧】怎么批量提取文件名到excel

Excel是大家经常用来制作表格的文件&#xff0c;比如输入文件名&#xff0c;如果有大量文件需要输入&#xff0c;用张贴复制或者手动输入的方式还是很费时间的&#xff0c;今天和大家分享如何批量提取文件名。 打开需要提取文件名的文件夹&#xff0c;选中所有文件&#xff0c…

HTML---JavaScript基础

文章目录 目录 文章目录 本章目标 一.JavaScript基础 概述 特点 JavaScript 基本机构 语法 网页中引用JavaScript的方式 二. JavaScript核心语法 变量 ​编辑 数据类型 数组 练习 本章目标 掌握JavaScript的组成掌握JavaScript的基本语法会定义和使用函数会使用工具进行…

[Angular] 笔记 22:ElementRef

chatgpt: ElementRef 是 Angular 中的一个类&#xff0c;它用于包装对 DOM 元素的引用。它允许开发者直接访问与 Angular 组件关联的宿主 DOM 元素。 当在 Angular 中需要直接操作 DOM 元素时&#xff0c;可以使用 ElementRef。通常情况下&#xff0c;最好避免直接操作 DOM&a…

【Transformer】深入理解Transformer模型1——初步认识了解

前言 Transformer模型出自论文&#xff1a;《Attention is All You Need》 2017年 近年来&#xff0c;在自然语言处理领域和图像处理领域&#xff0c;Transformer模型都受到了极为广泛的关注&#xff0c;很多模型中都用到了Transformer或者是Transformer模型的变体&#xff0…

OSPF的DR与BDR-新版(16)

目录 整体拓扑 操作步骤 1.基本配置 1.1 配置R1的IP 1.2 配置R2的IP 1.3 配置R3的IP 1.4 配置R4的IP 1.5 检测R1与R4连通性 1.6 检测R1与R2连通性 1.7 检测R1与R3连通性 2.搭建基本的OSPF网络 2.1 配置R1 OSPF 2.2 配置R2 OSPF 2.3 配置R3 OSPF 2.4 配置R4 OSPF…

前端八股文(工程化篇)

目录 1.常用的git命令有哪些&#xff1f; 2.git rebase和git merge的区别 3.有哪些常见的Loader和Plugin&#xff1f; 4.webpack的构建流程 5.bundle,chunk,module是什么&#xff1f; 6.如何提高webpack的打包速度 7.vite比webpack快在哪里 8.说一下你对Monorepo的理解 …

C语言函数篇——strcat()函数

strcat()函数介绍&#xff1a; strcat()函数是C语言中用于连接两个字符串的函数。它将第二个字符串连接到第一个字符串的末尾&#xff0c;并返回第一个字符串的地址。 strcat()函数的语法&#xff1a; char *strcat(char *dest, const char *src); 其中&#xff0c;dest是目标…

数字图像处理——亚像素边缘的轮廓提取

像素 像素是图像处理中的基本单位&#xff0c;一个像素是图像中最小的离散化单位&#xff0c;具有特定的位置和颜色信息。在数字图像中&#xff0c;每个像素都有一个特定的坐标&#xff0c;通常以行和列的形式表示。每个像素的颜色信息可以通过不同的表示方式&#xff0c;如灰…

大数据- Hadoop入门

目录 &#x1f436;2.1 hadoop的简介 1. 概述 2. 什么是分布式&#xff1f; 3. Hadoop的指代 &#x1f436;2.2 hadoop的发展历程 &#x1f436;2.3 hadoop的版本介绍 &#x1f436;2.4 hadoop的常用端口号 &#x1f436;2.5 hadoop的设计目的 &#x1f436;2.6 hadoo…

使用vmware,在ubuntu18.04中使用笔记本的摄像头

步骤1&#xff1a;在windows中检查相机状态 win10系统中&#xff0c;在左下的搜索栏&#xff0c;搜索“相机”&#xff0c;点击进入即可打开相机&#xff0c;并正常显示图像。 注意&#xff1a;如果相机连接到了虚拟机&#xff0c;则不能显示正常。 步骤2&#xff1a;在ubuntu…

轻松调整视频时长,创意与技术的新篇章

传统的视频剪辑工具往往难以精确控制时间&#xff0c;而【媒体梦工厂】凭借其先进的算法和界面设计&#xff0c;让视频时长的调整变得简单而精确&#xff0c;助你释放无限的创意&#xff0c;用技术为你的创意插上翅膀&#xff0c;让每一秒都有意义。 所需工具&#xff1a; 一…

【Matlab】BP 神经网络时序预测算法

资源下载&#xff1a; https://download.csdn.net/download/vvoennvv/88681507 一&#xff0c;概述 BP 神经网络是一种常见的人工神经网络&#xff0c;也是一种有监督学习的神经网络。其全称为“Back Propagation”&#xff0c;即反向传播算法。BP 神经网络主要由输入层、隐藏层…

1、aigc图像相关

aigc图像相关 一、Diffusion webui 在autodl上部署一些问题二、lora和kohyass&#xff08;1&#xff09;角色模型&#xff08;2&#xff09;风格模型&#xff08;3&#xff09;dreambooth&#xff08;4&#xff09;模型合并&#xff08;5&#xff09;Lora加Adetail其他 三、sd …

数模混合SoC芯片中LEF2Milkyway的golden flow

在数模混合芯片中的项目中&#xff0c;特别是数字模块很少甚至只有一个简单的数字控制逻辑时&#xff0c;我们要做数字模块的后端实现时&#xff0c;通常模拟那边会问我们实现需要他们提供哪些数据。 通常来说&#xff0c;我们可以让模拟设计提供数字模块的GDS或LEF文件即可。…

【LeetCode每日一题】1185.一周中的第几天(模拟+调用库函数:三种方法)

2023-12-30 文章目录 一周中的第几天方法一&#xff1a;模拟思路步骤 方法二&#xff1a;调用库函数方法三&#xff1a;调用库函数 一周中的第几天 ​ 提示&#xff1a;给出的日期一定是在 1971 到 2100 年之间的有效日期。 方法一&#xff1a;模拟 思路 1.可以根据1970年的…
最新文章