当前位置: 首页 > news >正文

Git 常用操作与注意事项全攻略

1. 基本配置

git config --global user.name "你的名字"
git config --global user.email "你的邮箱"
git config --list   # 查看当前配置

建议全局配置用户名和邮箱,否则提交记录可能不规范

2.仓库操作

初始化本地仓库
git init

只在新建项目时使用,已有仓库不用再 init。

克隆远程仓库
git clone 仓库地址
# 例:git clone git@codeup.aliyun.com:d1/dxInside/MU86.git

克隆后会自动进入项目目录,注意切换到正确目录再操作

3.分支操作

查看分支
git branch           # 查看本地分支
git branch -r        # 查看远程分支
git branch -a        # 查看所有分支
新建分支
git branch 分支名

新建分支不会自动切换,需手动切换。

切换分支
git checkout 分支名
# 或
git switch 分支名

切换前请确保当前更改已提交或已暂存,否则可能导致冲突。

新建并切换分支
git checkout -b 分支名
# 或
git switch -c 分支名
删除分支
git branch -d 分支名         # 删除本地分支(已合并)
git branch -D 分支名         # 强制删除本地分支(未合并)
git push origin --delete 分支名  # 删除远程分支

删除分支前请确认分支内容已备份或合并。

4. 代码提交

查看状态
git status
添加文件到暂存区
git add 文件名
git add .           # 添加所有更改

git add . 会添加所有更改,包括删除和新建,操作前请确认。

提交更改
git commit -m "提交说明"

提交说明建议简明扼要,便于团队协作。

5. 远程操作

查看远程仓库
git remote -v
添加远程仓库
git remote add origin 仓库地址

一个仓库可以有多个远程(如 origin、upstream),注意区分。

拉取远程代码
git pull                # 拉取当前分支对应的远程分支
git pull origin 分支名  # 拉取指定远程分支到当前分支

拉取前建议先提交本地更改,避免冲突。

推送代码到远程
git push                # 推送当前分支到远程
git push origin 分支名  # 推送当前分支到远程指定分支
git push -u origin 分支名  # 首次推送并建立关联

推送前建议先拉取远程最新代码,避免覆盖他人提交。

6. 合并与变基

合并分支
git merge 其他分支名

合并前建议先拉取最新代码,合并后如有冲突需手动解决。

变基(rebase)
git rebase 其他分支名

rebase 会重写提交历史,协作开发时慎用,避免影响他人。

7. 撤销与回退

撤销未提交的更改
git checkout -- 文件名

会丢弃文件的本地更改,谨慎操作。

撤销已暂存的更改
git reset HEAD 文件名
回退到某次提交
git log                # 查看提交历史,找到commit id
git reset --hard commit_id

–hard 会丢弃所有未提交的更改,操作前请备份重要内容。

8. 查看日志

git log
git log --oneline
git log --graph --all --decorate

–graph 选项可以更直观地查看分支合并关系。

9. 标签(Tag)

创建标签
git tag v1.0
推送标签
git push origin v1.0
git push origin --tags   # 推送所有标签
删除标签
git tag -d v1.0
git push origin :refs/tags/v1.0

10. stash 临时保存

保存当前更改
git stash
查看 stash 列表
git stash list
恢复最近一次 stash
git stash pop

11. 常见问题与注意事项

  • 切换分支前请提交或保存当前更改,否则可能导致冲突或丢失。
  • 多人协作时,推送前务必先拉取远程最新代码,解决冲突后再推送。
  • 不要在公共分支(如 master/main)上直接开发,建议新建 feature 分支开发后合并。
  • rebase 只建议在自己的分支上用,合并到主分支前请用 merge。
  • reset、rebase、push -f 等会重写历史,操作前请三思。
  • 删除分支、回退历史等危险操作前请做好备份。

12. 其他实用命令

查看某个文件的历史
git log 文件名
查看某次提交的内容
git show commit_id
比较差异
git diff                # 工作区与暂存区差异
git diff --cached       # 暂存区与上次提交差异
git diff 分支A..分支B   # 两分支差异
修改最后一次提交说明
git commit --amend
http://www.dtcms.com/a/273628.html

相关文章:

  • 华为数据通信网络基础
  • Python 【技术面试题和HR面试题】➕ 循环结构、控制语句及综合应用问答
  • [面试] 手写题-插入排序
  • 飞算JavaAI:新一代智能编码引擎,革新Java研发范式
  • 代账行业数字化破局:从“知道”到“做到”,三步走稳赢!
  • C++学习之C++中`std::fmax`和`std::max`的区别
  • pytorch的介绍以及张量的创建
  • Java中三种重要的锁
  • spring boot 详解以及原理
  • 界面设计工具——MasterGo莫高设计
  • 【UE教程/进阶】Slate链式编辑原理
  • 解决echarts数据更新了图表不更新
  • GPU 降成本免运维,睿观 AI 助手选择函数计算
  • 打破信息壁垒!可视化如何让交通数据 “开口说话”
  • C#元组:从基础到实战的全方位解析
  • 人脸图像生成(DCGAN)
  • Qt数据库编程详解:SQLite实战指南
  • Vue 3 中父组件内两个子组件相互传参的几种方法
  • Vue 3 入门——自学习版本
  • DOM编程实例(不重要,可忽略)
  • 分享|2025年机器学习工程师职业技术证书报考指南
  • 论容器化 | 分析Go和Rust做医疗的后端服务
  • 在vue中使用Three.js渲染FBX模型
  • arcgis api for js 设置地图服务请求带有请求头信息
  • 录音实时上传
  • uniapp
  • Claude Code是什么?国内如何使用到Claude Code?附国内最新使用教程
  • 基于定制开发开源AI智能名片与S2B2C商城小程序的旅游日志创新应用研究
  • uniapp小程序tabbar跳转拦截与弹窗控制
  • Elasticsearch混合搜索深度解析(上):问题发现与源码探索