Contents

git 常用命令

Git 使用指南

Git 是一个分布式版本控制系统,被广泛应用于软件开发领域。本文将介绍 Git 的常用用法以及在工作中可能遇到的高级用法。

Git 基础

配置

在开始使用 Git 之前,我们需要做一些基本的配置。执行以下命令设置您的用户名和电子邮件地址:

1
2
git config --global user.name "Your Name"
git config --global user.email "your@email.com"

初始化仓库

要创建一个新的 Git 仓库,请在您的项目目录中执行以下命令:

1
git init

该命令将创建一个新的 .git 目录,用于保存项目的版本信息。

添加和提交更改

在开发过程中,您可以使用以下命令将文件添加到暂存区并提交更改:

1
2
3
git add file1.txt file2.js # 添加指定文件到暂存区
git add . # 添加所有更改到暂存区
git commit -m "Commit message" # 提交更改并添加提交信息

分支管理

Git 支持使用分支来隔离开发工作流,以避免直接修改主代码库。以下是一些常见的分支操作命令:

1
2
3
4
git branch # 列出所有分支
git branch new-feature # 创建新的分支
git checkout new-feature # 切换到新的分支
git merge new-feature # 将新的分支合并到当前分支

远程仓库

要与远程仓库进行交互,您需要先添加远程仓库的 URL:

1
git remote add origin https://github.com/username/repo.git

然后,您可以使用以下命令来推送本地提交到远程仓库或从远程仓库拉取最新更改:

1
2
git push origin master # 推送本地 master 分支到远程仓库
git pull origin master # 从远程仓库拉取 master 分支并合并到本地

Git 高级用法

撤销更改

有时您可能需要撤销某些提交或更改。以下是一些常见的撤销操作命令:

1
2
3
4
git checkout -- file.txt # 撤销对某个文件的更改
git reset HEAD file.txt # 取消暂存某个文件
git reset HEAD^ # 撤销最后一次提交
git revert HEAD # 创建一个新的提交来撤销之前的提交

储藏和清理

在某些情况下,您可能需要暂时将当前的更改存储起来,以切换到其他分支或清理工作目录。Git 提供了 stash 命令来实现此目的:

1
2
3
git stash # 将当前更改保存到存储区
git stash apply # 重新应用最近一次存储的更改
git stash drop # 删除最近一次存储的更改

您还可以使用 git clean 命令删除未跟踪的文件:

1
2
git clean -n # 显示将要删除的未跟踪文件
git clean -f # 删除所有未跟踪的文件

子模块

Git 子模块允许您在一个 Git 仓库中包含另一个 Git 仓库作为子目录。这在处理大型项目时非常有用,可以将项目拆分为多个独立的仓库。以下是一些常见的子模块操作命令:

1
2
3
git submodule add https://github.com/username/library.git lib # 添加子模块
git submodule init # 初始化子模块
git submodule update # 更新子模块

重写历史记录

在某些情况下,您可能需要重写 Git 提交历史记录。这可能是为了清理提交信息、合并提交或从历史记录中删除敏感信息。Git 提供了 rebase 命令来实现此目的:

1
2
git rebase -i HEAD~3 # 交互式重写最近三次提交
git filter-branch --tree-filter 'rm -f file.txt' HEAD # 从整个历史记录中删除文件

请注意,重写历史记录会改变提交的 SHA-1 哈希值,因此您应该只在本地分支上执行此操作,并且不应重写已推送到远程仓库的提交。

总结

Git 是一个功能强大的版本控制系统,提供了许多有用的功能来管理您的代码库。本文介绍了 Git 的常用用法和一些高级用法,希望能为您在工作中使用 Git 提供一些指导。当然,Git 还有更多高级功能等待您去探索和学习。