news 2026/4/21 8:49:10

轻松玩转Git:图文详解常用命令与操作

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
轻松玩转Git:图文详解常用命令与操作

Git简介

git是一个开源的分布式版本控制系统,可以有效、高速地处理从很小到很大的项目版本管理。

特点:

  • 速度快
  • 简单的设计
  • 对非线性开发模式的强力支持(允许成千上万个并行开发的分支)
  • 完全分布式
  • 有能力高效管理类似Linux内核一样超大规模的项目(速度和数据量)

Git工作流程图

命令如下:

  1. clone(克隆):从远程仓库中克隆代码到本地仓库。
  2. checkout(检出):从本地仓库中检出一个仓库分支然后进行修订。
  3. add(添加):在提交前先将代码提交到暂存区。
  4. commit(提交):提交到本地仓库。本地仓库中保存修改的各个历史版本。
  5. fetch(抓取):从远程库,抓取到本地仓库,不进行任何的合并动作,一般操作比较少。
  6. pull(拉取):从远程库拉到本地库,自动进行合并(merge),然后放到到工作区,相当于fetch+merge。
  7. push(推送):修改完成后,需要和团队成员共享代码时,将代码推送到远程仓库。

Git获取本地仓库

在任意一个文件夹中打开Git Bash窗口,然后输入git init并执行,出现.git隐藏文件则创建成功。

Git常用基础命令

文件忽略列表

一般我们总会有些文件无需纳入Git的管理,也不希望它们总出现在未跟踪文件列表。通常都是些自动生成的文件,比如日志文件,或者编译过程中创建的临时文件等。在这种情况下,我们可以在工作目录中创建一个名为.gitignore 的文件(文件名称固定),列出要忽略的文件模式。

操作:

在工作目录下创建一个.gitignore文件,在里面写上无序Git管理的文件模式,例如:*.a就是以.a结尾的文件

基础操作:

1、add:添加工作区到暂存区

git add 文件名/通配符

2、commit:提交暂存区到本地仓库

git commit -m '注释内容'

3、status:查看修改的状态

git status

4、log:查看提交日志

git log 选项

  • –all:显示所有分支
  • –pretty=oneline:将提交信息显示为一行
  • –abbrev-commit:使得输出的commitld更简短
  • –graph:以图的形式显示
5、reflog:查看删除的日志

git reflog

可以看到已经删除的提交记录

6、reset:版本切换

git reset --hard commitid

commitid可以查看通过日志查看

**PS:**对于一些比较长的命令可以在~目录下创建一个.bashrc文件,在文件中定义命令的别名,例如:

aliasgit-log='git log --pretty=oneline --all --graph --abbrev-commit'aliasll='ls -al'

之后在你的工作目录下执行source ~/.bashrc

分支操作:

1、branch:查看/创建/删除本地分支

git branch

git branch 分支名

git branch -vv显示的更加详细,例如关联关系

不能删除当前分支,只能删除其他分支

git branch -d 其他分支名删除分支时,需要做各种检查

git branch -D 其他分支名删除分支时,不做任何检查,强制删除

2、checkout:切换分支

git checkout 分支名

git checkout -b 分支名创建并切换到一个不存在的分支

3、merge:合并分支

一个分支上的提交可以合并到领一个分支

git merge 分支名

合并冲突:

当两个分支对同一个文件的数据修改存在冲突时,需要手动处理冲突。

  1. 处理文件中冲突的地方
  2. 将解决完冲突的文件放到暂存区(add)
  3. 提交到仓库(commit)
分支应用流程:

Git远程仓库

使用远程仓库

1、remote:添加/查看远程仓库

git remote add <远端名称> <远程仓库路径>

远端名称默认是origin

示例:git remote add origin https://github.com/6moran/git_test.git

git remote查看远程仓库

git remote -v查看远程仓库,详细。

2、push:推送到远程仓库

git push [-f] [--set-upstream] [远端名称 [本地分支名][:远端分支名]]

如果远端分支名和本地分支名相同,只写本地分支名即可。

-f:强制覆盖

--set-upstream推送到远端的同时并且建立起和远端分支的关联关系(一般第一次推送时使用)

如果当前分支已经和远端分支关联,则可以省略分支名和远端名,直接git push将master分支推送到已关联的远端分支。

3、clone:从远程仓库克隆

git clone 仓库链接 [本地目录名称]

仓库链接如下:

4、fetch:从远程仓库抓取到本地,不会进行合并

git fetch [remote name] [branch name]

如果不指定远端名称,那么抓取所有分支。

5、pull:从远端仓库拉取到本地并自动合并

git pull [remote name] [branch name]

相当于fetch+merge

如果不指定远端名称和分支名,则拉取所有,并更新当前分支。

Git使用铁令

  • 切换分支前先提交本地的修改。
  • 代码及时提交,提交过了就不会丢。
  • 遇到任何问题都不要删除文件目录。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/20 19:18:14

当暴雪来袭:软件系统的容错启示录

引言&#xff1a;白色灾难的数字化映射2025年末席卷华北的世纪暴雪导致交通瘫痪、电网崩溃、物流中断。这场持续96小时的极端天气事件&#xff0c;恰似一次对现代城市运行系统的全链路压力测试。当我们复盘供电网络崩溃的三级连锁故障时&#xff0c;软件测试从业者敏锐地发现&a…

作者头像 李华
网站建设 2026/4/20 9:18:10

文化事件嫁接:本地化测试中的敏感场景处置方法论

一、文化事件嫁接的测试学定义 在本地化测试范畴中&#xff0c;文化事件嫁接特指将源语言文化背景中的特定元素&#xff08;如节日符号、历史隐喻、社会习俗&#xff09;迁移至目标文化环境时产生的认知冲突现象。2025年Forrester调研显示&#xff0c;78%的跨国数字产品本地化…

作者头像 李华
网站建设 2026/4/19 19:35:50

Android 15 ServiceManager与Binder服务注册深度解析

引言 在上一篇文章中,我们深入分析了Binder驱动的内核机制。但是有一个核心问题还没有回答:Client如何知道Server的Binder句柄? 想象一下,你想打电话给朋友,但你不知道他的电话号码。这时你需要查电话簿(Yellow Pages)。在Android系统中,ServiceManager就是这本"电话簿…

作者头像 李华
网站建设 2026/4/18 3:04:04

气候事件应用:云原生系统弹性测试设计

1. 总述&#xff1a;云原生系统与气候事件弹性测试概述 随着气候变化加剧&#xff0c;极端天气事件&#xff08;如洪水、飓风、热浪&#xff09;频发&#xff0c;对数字化基础设施构成严峻挑战。云原生系统&#xff08;Cloud-Native Systems&#xff09;&#xff0c;基于微服务…

作者头像 李华
网站建设 2026/4/18 22:17:54

‌金融波动场景下的交易流程稳定性测试强化

‌一、背景&#xff1a;金融波动如何重塑测试范式‌ 金融市场的瞬时波动——如美股闪崩、人民币汇率跳水、加密资产暴跌——正从“偶发风险”演变为“常态压力源”。2023年中信证券因UPS断电导致交易系统中断19分钟&#xff0c;2025年支付宝消息库局部故障引发支付卡顿&#x…

作者头像 李华
网站建设 2026/4/18 1:13:18

CAD加密软件哪个好?2026精选5款CAD加密软件,千万别错过

你的核心图纸&#xff0c;可能正被竞争对手“免费预览”。要知道CAD图纸作为企业的设计命脉&#xff0c;一旦泄露&#xff0c;损失动辄百万。设计师熬夜赶稿&#xff0c;老板投入重金研发&#xff0c;却因安全漏洞让设计成果付诸东流&#xff0c;这会让多少老板痛彻心扉。别担心…

作者头像 李华