git的常用命令详解

Git 是一个分布式版本控制系统,常用于软件开发中的代码管理。以下是一些 Git 的常用命令详解:

仓库操作

1. git init
  • 作用:在当前目录下初始化一个新的 Git 仓库。
  • 示例
bash 复制代码
git init

执行此命令后,当前目录会生成一个隐藏的 .git 文件夹,这是 Git 仓库的核心,包含了版本控制所需的所有元数据。

2. git clone <repository>
  • 作用:从远程仓库克隆一份代码到本地。
  • 示例
bash 复制代码
git clone https://github.com/username/repository.git

这会将指定的远程仓库克隆到当前目录下一个以仓库名命名的文件夹中。

提交操作

1. git add <file>
  • 作用:将文件添加到暂存区。暂存区是一个中间区域,用于准备提交的文件。
  • 示例
bash 复制代码
git add example.txt

如果要添加当前目录下的所有文件,可以使用:

bash 复制代码
git add .
2. git commit -m "<message>"
  • 作用:将暂存区的文件提交到本地仓库,并添加一条描述性的提交信息。
  • 示例
bash 复制代码
git commit -m "Add example.txt"

查看状态和日志

1. git status
  • 作用:查看当前工作目录和暂存区的状态,显示哪些文件被修改、添加或删除。
  • 示例
bash 复制代码
git status

执行该命令后,会输出当前工作目录的状态信息,如哪些文件已修改但未添加到暂存区,哪些文件已添加到暂存区等待提交等。

2. git log
  • 作用:查看提交历史记录,包括提交的哈希值、作者、日期和提交信息。
  • 示例
bash 复制代码
git log

如果只想查看最近几条提交记录,可以使用:

bash 复制代码
git log -n 3

这会显示最近的 3 条提交记录。

分支操作

1. git branch
  • 作用:列出本地仓库的所有分支。
  • 示例
bash 复制代码
git branch
2. git branch <branch-name>
  • 作用:创建一个新的分支。
  • 示例
bash 复制代码
git branch new-feature

这会创建一个名为 new-feature 的新分支。

3. git checkout <branch-name>
  • 作用:切换到指定的分支。
  • 示例
bash 复制代码
git checkout new-feature

如果要创建并切换到一个新分支,可以使用:

bash 复制代码
git checkout -b new-feature
4. git merge <branch-name>
  • 作用:将指定分支的修改合并到当前分支。
  • 示例
bash 复制代码
git merge new-feature

这会将 new-feature 分支的修改合并到当前所在的分支。

远程仓库操作

1. git remote add <name> <url>
  • 作用:将本地仓库与远程仓库关联起来。
  • 示例
bash 复制代码
git remote add origin https://github.com/username/repository.git

这里的 origin 是远程仓库的常用别名,你可以根据需要自定义。

2. git push <remote> <branch>
  • 作用:将本地仓库的提交推送到远程仓库。
  • 示例
bash 复制代码
git push origin main

这会将本地 main 分支的提交推送到远程仓库的 main 分支。

3. git pull <remote> <branch>
  • 作用:从远程仓库拉取最新的提交并合并到本地分支。
  • 示例
bash 复制代码
git pull origin main

这会从远程仓库的 main 分支拉取最新的提交,并将其合并到本地的 main 分支。

撤销操作

1. git reset <file>
  • 作用:将文件从暂存区移除,但不会改变文件的内容。
  • 示例
bash 复制代码
git reset example.txt
2. git checkout -- <file>
  • 作用:丢弃工作目录中文件的修改,将文件恢复到上一次提交的状态。
  • 示例
bash 复制代码
git checkout -- example.txt

这些是 Git 的一些常用命令,掌握它们可以帮助你有效地管理代码版本。在实际使用中,你可能还会遇到更复杂的情况,需要结合其他命令和选项来完成任务。

相关推荐
To_OC3 小时前
从一次栈溢出报错说起,我把递归彻底扒明白了
javascript·算法·程序员
kyriewen5 小时前
面试官问你:“AI 能写 80% 的代码了,公司为什么还需要你?”
前端·javascript·面试
Goodbye8 小时前
从 Token 到 Embedding:LLM 核心基础深度解析
javascript·人工智能
用户938515635078 小时前
工具调用背后:LLM 如何突破“缸中大脑”,操控真实世界?
javascript·人工智能
Goodbye8 小时前
从函数到智能:LLM Tool Use 深度解析
javascript·人工智能
半个落月8 小时前
大模型到底是怎么“调用工具”的?从一个 Node.js Demo 看懂 Tool Use
javascript·人工智能
烬羽8 小时前
中英文 token 数量差一倍?两段 JS 代码搞懂 LLM 底层是怎么"读"文字的
javascript·程序员·架构
山河木马8 小时前
矩阵专题1-怎么创建模型矩阵(uModelMatrix)
javascript·webgl·计算机图形学
前端开发爱好者13 小时前
支持 110 种文件预览!兼容 Vue、React、Svelte!
前端·javascript·vue.js
大家的林语冰14 小时前
👍 尤大重学 Webpack,Vite 8.1 再进化,打包模式复活!
前端·javascript·vite