Git的常用操作命令

Git是一个分布式版本控制系统,广泛应用于软件开发项目中来追踪和控制代码的修改历史。

Git常用命令如下:

配置用户信息

复制代码
   # 设置全局用户名和邮箱
   git config --global user.name "Your Name"
   git config --global user.email "youremail@example.com"

初始化仓库

复制代码
   # 在当前目录创建一个新的Git仓库
   git init

克隆仓库

复制代码
   # 克隆远程仓库至本地
   git clone https://github.com/user/repo.git

添加文件到暂存区

复制代码
   # 将某个文件添加到暂存区以准备提交
   git add <file_path>
   # 或者添加所有改动
   git add .

提交更改

复制代码
   # 提交暂存区的内容到本地仓库,附带提交信息
   git commit -m "Initial commit or describe your changes here"

查看状态

复制代码
   # 检查工作区和暂存区的状态
   git status

拉取远程更新

复制代码
   # 获取远程仓库的最新改动并尝试自动合并到当前分支
   git pull origin <branch_name>

推送更改

复制代码
   # 将本地分支的更改推送到远程仓库的对应分支
   git push origin <branch_name>

创建与切换分支

复制代码
   # 创建并立即切换到新的分支
   git checkout -b new_branch
   # 切换回已有分支
   git checkout <existing_branch>
复制代码
#### **查看分支**:

    # 显示所有本地分支
    git branch
    # 显示所有本地和远程分支
    git branch -a
复制代码
#### **解决冲突与合并分支**:

    # 合并指定分支到当前分支
    git merge other_branch
复制代码
#### **stash暂存未提交的更改**:

    # 暂存所有未提交的更改
    git stash
    # 恢复最近暂存的更改
    git stash pop
复制代码
#### **查看提交历史**:

    # 显示提交历史记录
    git log
复制代码
#### **Cherry-pick**:

    # 将指定提交应用到当前分支
    git cherry-pick <commit_hash>
复制代码
#### **撤销更改**:

*

  ##### 取消暂存区的更改:

      git reset <file_path>  # 将指定文件从暂存区移除,但保留工作区的更改
      git reset HEAD <file_path>  # 类似于上述命令,取消暂存的同时恢复到HEAD版本

*

  ##### 回滚工作区的更改:

      git checkout -- <file_path>  # 抛弃工作区对指定文件的更改
复制代码
#### **删除文件**:

*

  ##### 从版本库和工作区一起删除:

      git rm <file_path>
      git commit -m "Remove file"

*

  ##### 仅从版本库中删除(保留工作区文件):

      git rm --cached <file_path>
      git commit -m "Remove file from repository"
复制代码
#### **重命名/移动文件**:

    git mv <old_file_path> <new_file_path>
    git commit -m "Rename/move file"
复制代码
#### **查看不同版本间的差异**:

    git diff  # 查看尚未暂存的改动
    git diff --staged  # 查看已暂存但未提交的改动
    git diff <commit1> <commit2>  # 查看两个提交之间的差异
复制代码
#### **回退到以前的提交**:

    # 回退到某一提交,并且丢弃之后的所有更改(谨慎操作)
    git reset --hard <commit_hash>
复制代码
#### **标签管理**:

*

  ##### 创建标签:

      git tag <tag_name> <commit_hash>  # 标记特定提交
      git tag <tag_name>  # 标记当前HEAD指向的提交

*

  ##### 推送标签到远程仓库:

      git push origin <tag_name>

*

  ##### 删除标签:

      git tag -d <tag_name>
      git push origin :refs/tags/<tag_name>  # 删除远程标签
复制代码
#### **stash栈操作**:

*

  ##### 存储未提交的更改并清理工作区(保存现场):

      git stash

*

  ##### 列出stash列表:

      git stash list

*

  ##### 应用stash中的某个更改:

      git stash apply <stash@{index}>

*

  ##### 永久应用并删除stash:

      git stash pop
复制代码
#### **子模块操作**:

*

  ##### 添加子模块:

      git submodule add <repository_url> <path_to_submodule>

*

  ##### 更新子模块:

      git submodule update --remote
复制代码
#### **交互式暂存(添加部分更改)**:

    git add -p
复制代码
#### **Rebase(变基)**:

    # 将feature分支的更改重新应用到master分支上,保持线性历史
    git checkout feature
    git rebase master
    git checkout master
    git merge feature
相关推荐
用户1563068103511 小时前
Day01 | Java 基础(Java SE)
java
Pedantic1 小时前
SwiftUI 手势层级(Gesture Hierarchy)详解
前端
飘尘1 小时前
前端转型全栈(Java后端)的快速上手指引
前端·后端·全栈
一颗烂土豆1 小时前
Meshopt 压缩深度解析,为什么它比 Draco 更快
前端·javascript·webgl
浏览器工程师2 小时前
AI Agent 接浏览器任务,先别让它一路点到底
前端·后端
行者全栈架构师2 小时前
Maven dependency:tree 的 8 个高级用法
java·后端
雨季mo浅忆2 小时前
VSCode自动格式化三要素
前端
Chenyiax2 小时前
从一次请求看懂 OkHttp:架构、调度与连接管理
后端
爱勇宝3 小时前
深扒 Anthropic 1680 位工程师简历:应届生几乎没机会,AI 公司最缺的不是博士
前端·后端·程序员