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
相关推荐
Lisonseekpan1 分钟前
Spring Boot 中使用 Caffeine 缓存详解与案例
java·spring boot·后端·spring·缓存
为java加瓦4 分钟前
Rust 的类型自动解引用:隐藏在人体工学设计中的魔法
java·服务器·rust
SimonKing7 分钟前
分布式日志排查太头疼?TLog 让你一眼看穿请求链路!
java·后端·程序员
袁煦丞8 分钟前
一图看懂Docker管理 Portainer:cpoar内网穿透实验室第652个成功挑战
前端·程序员·远程工作
鸽鸽程序猿15 分钟前
【Git】 远程操作 与 标签管理
git
消失的旧时光-194319 分钟前
Kotlin 判空写法对比与最佳实践
android·java·kotlin
小许学java22 分钟前
Spring AI快速入门以及项目的创建
java·开发语言·人工智能·后端·spring·ai编程·spring ai
右子34 分钟前
微信小程序开发“闭坑”指南
前端·javascript·微信小程序
一叶飘零_sweeeet42 分钟前
从 “死锁“ 到 “解耦“:重构中间服务破解 Java 循环依赖难题
java·循环依赖
入秋1 小时前
Three.js后期处理实战:噪点 景深 以及色彩调整
前端·javascript·three.js