Git基础

Git是一个广泛使用的分布式版本控制系统,它允许开发者高效地协作和管理代码的历史版本。以下是Git中一些最常用的操作命令。

git init

初始化一个新的Git仓库。在你的项目目录中运行此命令,会创建一个新的.git子目录,这个目录包含所有Git的版本跟踪元数据。

git clone

克隆一个已存在的Git仓库。这个命令会创建一个与远程仓库同步的本地副本。

bash 复制代码
git clone <repository-url>

git add

将文件添加到暂存区域(staging area)。在你修改了一些文件之后,使用git add来添加这些改动,准备进行下一次的提交。

bash 复制代码
git add <file-or-directory>
git add .

git commit

将暂存区域的改动提交到仓库。每一次提交都会记录下相关的改变,并附上一条提交信息。

bash 复制代码
git commit -m "Commit message"

git status

查看仓库当前的状态,包括哪些文件被修改了但还没有提交,哪些文件已经暂存了,等待下次提交。

git push

将本地的提交推送到远程仓库。

bash 复制代码
git push <remote-name> <branch-name>

git pull

从远程仓库拉取最新的改动,并合并到本地分支。

bash 复制代码
git pull <remote-name> <branch-name>

git fetch

从远程仓库获取最新的分支和数据,但不自动合并到本地分支。

bash 复制代码
git fetch <remote-name>

git checkout

  1. 切换分支git checkout <branch>用于切换到另一个分支。
  2. 创建并切换到新分支git checkout -b <new-branch>会创建一个新的分支并切换到该分支。
  3. 检出文件git checkout -- <file>可以丢弃工作区中某个文件的修改,将其恢复到最后一次提交时的状态。

git branch

查看、创建或删除分支。

bash 复制代码
git branch # 查看分支
git branch <new-branch> # 创建分支
git branch -d <branch> # 删除分支

git merge

将指定分支的改动合并到当前分支。

bash 复制代码
git merge <branch>

git log

查看提交历史记录。

bash 复制代码
git log

git diff

查看暂存区和工作区的差异,或是查看不同提交间的差异。

bash 复制代码
git diff # 查看工作区与暂存区的差异
git diff --staged # 查看暂存区与最后一次提交的差异

git revert

创建一个新的提交,用于撤销之前的提交。这是一种安全的取消更改的方式,因为它不影响项目的历史记录。

bash 复制代码
git revert <commit-hash>

git reset

将当前分支回退到指定的状态。git reset具有多种模式(--soft, --mixed, --hard),可以根据需要重置暂存区或工作区。

bash 复制代码
git reset <commit-hash>

以上是Git最常用的一些基本操作。Git还有更多的命令和选项可以完成各种高级版本管理任务。记得在进行某些可能会影响项目历史的操作前(比如git resetgit revert),一定要确保理解它们的行为,以避免意外的数据丢失。

相关推荐
南山nash37 分钟前
git从入门到熟练
git
夜流冰3 小时前
Git - GitForWindows
git
一个很帅的帅哥4 小时前
部署chat-vue
大数据·git·elasticsearch
芒鸽4 小时前
鸿蒙PC使用ffmpeg+electron实现视频中音频的提取
git
SunkingYang5 小时前
使用TortoiseGit工具推送(push)时,忘了先拉取(Pull),提示冲突,后续怎么处理冲突?
git·tortoisegit·pull·push·推送·冲突·拉取
BestOrNothing_20155 小时前
Git 团队开发冲突合并全流程:本地是否改动 + 远端是否更新,如何正确同步并合并(同分支/不同分支下的几种场景)
git·分支管理·git pull·git merge·分支冲突·git协作·git fetch
zzlyyds6 小时前
工作的时候遇到的git版本冲突与合并问题
git
BestOrNothing_20156 小时前
Git fetch 详解:git fetch 和 git fetch origin 到底有什么区别?(origin/xxx、远端跟踪分支一次讲透)
git·分支管理·开发规范·新手教程·fetch / origin·本地/远程 分支·detached head
gsls2008086 小时前
服务器状态监控Uptime Kuma
运维·服务器·git
XiaoHu02076 小时前
Linux进程间通信
linux·运维·服务器·c++·git·vscode