自从学会Git,感觉打开了一扇新大门

“同事让我用 Git 提交代码,我居然直接把项目文件压缩发过去了……”相信很多初学者都经历过类似的窘境。而当你真正掌握 Git 时,才会发现它就像一本魔法书,轻松解决代码管理的种种难题。

为什么 Git 能成为程序员的标配工具?它究竟打开了怎样一扇“大门”?

从自由职业者到大厂团队,Git 已成为代码管理的行业标准。无论是初创团队,还是拥有数百开发者的企业,Git 都在无形中提升了开发效率,成为推动科技发展的幕后英雄。

Git 的核心魅力
  1. 版本控制,让历史可追溯

    • 还记得重构后无法回滚的日子吗?Git 的分支功能,帮你保留每一个阶段的代码历史。
  2. 多人协作,团队效率倍增

    • 再也不用担心文件命名如“final_v2.1_last_final.docx”这样的混乱场景,Git 的 pull 和 merge 让团队协作如丝般顺滑。
  3. 分支管理,开发测试两不误

    • 新功能开发、BUG 修复可以独立在分支中进行,确保主分支稳定。

Git 是目前最流行的分布式版本控制系统,被广泛应用于软件开发项目中 它提供了许多命令和功能,可以帮助开发者有效地管理代码。本文将介绍Git的常见命令及其用法,帮助你快速上手并提升代码管理的效率 

1. 初始化与配置 

  • git init:

    初始化一个新的Git仓库。 

  • git config:

    配置Git的全局或局部设置,如用户名、邮箱等。 

2. 代码管理 

  • git add:

    将修改的文件添加到暂存区。 

  • git commit:

    将暂存区的文件提交到本地仓库。 

  • git status:

    查看当前代码状态,包括已修改、已暂存等。 

  • git diff:

    查看文件在工作区与暂存区或本地仓库的差异。 

3. 分支操作 

  • git branch:

    查看、创建或删除分支。 

  • git checkout:

    切换分支或恢复文件到上一个版本。 

  • git merge:

    合并分支。 

  • git rebase:

    将一个分支的提交应用到另一个分支上。 

4. 远程仓库 

  • git remote:

    管理远程仓库的操作,如添加、删除、重命名远程仓库。 

  • git clone:

    克隆远程仓库到本地。 

  • git pull:

    拉取远程仓库的最新代码。 

  • git push:

    推送本地代码到远程仓库。 

5. 撤销与回退 

  • git revert:

    撤销某个提交并生成一个新的提交。 

  • git reset:

    回退到指定的提交或重置暂存区与工作区。 

  • git stash:

    暂存当前的修改,以便切换分支或恢复。 

6. 历史记录 

  • git log:

    查看提交历史记录。 

  • git blame:

    显示文件每一行的修改信息。 

  • git show:

    查看某个提交的详细信息。 

7. 标签管理 

  • git tag:

    管理标签,如创建、查看、删除标签。 

  • git push --tags:

    推送本地标签到远程仓库。 

8. 忽略文件与配置文件

  • .gitignore:

    配置忽略某些文件或目录。

  • .gitattributes:

    配置文件属性,如文件换行符、二进制文件等。

9. 远程仓库管理 

  • git remote add <remote-name> <remote-url>:

    添加一个新的远程仓库。 

  • git remote -v:

    查看当前配置的所有远程仓库。 

  • git fetch <remote-name>:

    从远程仓库获取最新的代码,但不合并到当前分支。 

  • git remote show <remote-name>:

    查看远程仓库的详细信息。 

10. 撤销与修改 

  • git checkout – <file-name>:

    丢弃工作区的修改,恢复到最近一次提交的状态。 

  • git reset HEAD <file-name>:

    取消暂存文件,将文件从暂存区移回到工作区。 

  • git commit --amend:

    修改最后一次提交的消息或内容。 

11. 版本比较和提交历史 

  • git diff <commit1> <commit2>:

    比较两个提交之间的差异。 

  • git log --oneline:

    以简洁的方式显示提交历史记录。 

  • git show <commit>:

    查看指定提交的详细信息,包括修改的文件和内容变动。 

12. 合并与解决冲突 

  • git merge <branch-name>:

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

  • git mergetool:

    使用可视化工具解决合并冲突。 

  • git diff --check:

    查找潜在的合并冲突。 

13. 分支管理 

  • git branch -d <branch-name>:

    删除指定的本地分支。 

  • git branch -m <old-branch-name> <new-branch-name>:

    重命名本地分支。 

  • git branch -a:

    查看所有本地和远程分支。

14. 撤销提交 

  • git revert <commit>:

    创建一个新的提交,撤销指定的提交内容。 

  • git reset <commit>:

    将分支指针移动到指定的提交,丢弃该提交之后的提交历史。 

15. 子模块管理 

  • git submodule add <repository-url> :

    将一个仓库作为子模块添加到当前仓库中。 

  • git submodule update --init --recursive:

    初始化并更新子模块。 

  • git submodule foreach <command>:

    为每个子模块执行指定的命令。 

16. 远程操作 

  • git push <remote-name> <branch-name>:

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

  • git pull <remote-name> <branch-name>:

    从远程仓库获取更新并合并到当前分支。 

  • git clone <repository-url> :

    克隆远程仓库到本地。

17. 其他常用命令 

  • git stash:

    将当前的未提交修改保存到堆栈中,方便切换分支或者储存临时修改。

  • git cherry-pick <commit>:

    选择一个或多个提交,将其应用到当前分支中。 

  • git clean -n:

    列出将要被删除的未被跟踪的文件和目录。

  • git blame <file-name>:

    逐行显示指定文件的修改历史和作者信息。

这只是一部分Git命令的示例,Git拥有丰富的功能和命令,可根据需要进行深入学习和使用。

掌握 Git,不只是学会了一门工具,而是拥有了驾驭代码的能力。它让你从手忙脚乱到有条不紊,打开了现代开发的大门。

“Git 之于开发者,就像画笔之于艺术家,工具虽小,却承载了无限可能。”

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/946772.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

简易屏幕共享工具-基于WebSocket

前面写了两个简单的屏幕共享工具&#xff0c;不过那只是为了验证通过截屏的方式是否可行&#xff0c;因为通常手动截屏的频率很低&#xff0c;而对于视频来说它的帧率要求就很高了&#xff0c;至少要一秒30帧率左右。所以&#xff0c;经过实际的截屏工具验证&#xff0c;我了解…

yakit-靶场-高级前端加解密与验签实战(for嵌套纯享版)

高级前端加解密与验签实战 一、前端验证签名&#xff08;验签&#xff09;表单&#xff1a;HMAC-SHA256 使用hmac-sha256的十六进制key值可以加密 与页面加密后的值相同 热加载&#xff1a; encryptData func(p) { //sha256key值key codec.DecodeHex("313233343132333…

嵌入式入门Day35

网络编程 Day2 套接字socket基于TCP通信的流程服务器端客户端TCP通信API 基于UDP通信的流程服务器端客户端 作业 套接字socket socket套接字本质是一个特殊的文件&#xff0c;在原始的Linux中&#xff0c;它和管道&#xff0c;消息队列&#xff0c;共享内存&#xff0c;信号等…

模仿微信小程序wx.showModal自定义弹窗,内容可以修改

实现以下弹框样式功能 1.在components新建一个文件showModel.wpy作为组件&#xff0c;复制下面代码 <style lang"less" scoped> .bg_model {display: flex;justify-content: center;align-items: center;// 弹框背景.bg_hui {width: 100%;height: 100%;posi…

如何在 Ubuntu 22.04 上安装并开始使用 RabbitMQ

简介 消息代理是中间应用程序&#xff0c;在不同服务之间提供可靠和稳定的通信方面发挥着关键作用。它们可以将传入的请求存储在队列中&#xff0c;并逐个提供给接收服务。通过以这种方式解耦服务&#xff0c;你可以使其更具可扩展性和性能。 RabbitMQ 是一种流行的开源消息代…

分布式系统架构6:链路追踪

这是小卷对分布式系统架构学习的第6篇文章&#xff0c;关于链路追踪&#xff0c;之前写过traceId的相关内容&#xff1a;https://juejin.cn/post/7135611432808218661&#xff0c;不过之前写的太浅了&#xff0c;且不成系统&#xff0c;只是简单的理解&#xff0c;今天来捋一下…

python opencv的orb特征检测(Oriented FAST and Rotated BRIEF)

官方文档&#xff1a;https://docs.opencv.org/4.10.0/d1/d89/tutorial_py_orb.html SIFT/SURF/ORB对比 https://www.bilibili.com/video/BV1Yw411S7hH?spm_id_from333.788.player.switch&vd_source26bb43d70f463acac2b0cce092be2eaa&p80 ORB代码 import numpy a…

蓝桥杯JAVA刷题--001

文章目录 题目需求2.代码3.总结 题目需求 2.代码 class Solution {public String convertDateToBinary(String date) {if (date null || date.length() ! 10 || date.charAt(4) ! - || date.charAt(7) ! -) {throw new IllegalArgumentException("输入的日期格式不正确&…

WebRTC的线程事件处理

1. 不同平台下处理事件的API&#xff1a; Linux系统下&#xff0c;处理事件的API是epoll或者select&#xff1b;Windows系统下&#xff0c;处理事件的API是WSAEventSelect&#xff0c;完全端口&#xff1b;Mac系统下&#xff0c;kqueue 2. WebRTC下的事件处理类&#xff1a; …

zentao ubuntu上安装

#下载ZenTaoPMS-21.2-zbox_amd64.tar.gz&#xff08;https://www.zentao.net/downloads.html&#xff09; https://dl.zentao.net/zentao/21.2/ZenTaoPMS-21.2-zbox_amd64.tar.gzcd /opt tar -zxvf ZenTaoPMS-21.2-zbox_amd64.tar.gz#启动 /opt/zbox/zbox start /opt/zbox/zbox…

LeetCode算法题——有序数组的平方

题目描述 给你一个按非递减顺序排序的整数数组nums&#xff0c;返回每个数字的平方组成的新数组&#xff0c;要求也按非递减顺序排序。 题解 解法一&#xff1a;暴力解法 思路&#xff1a; 该题目可通过暴力解法解决&#xff0c;即利用for循环遍历数组&#xff0c;对数组每…

vue v-for 数据增加页面不刷新

<div style"float:left;border:1px solid red;height:100px;width:600px;"><el-form-item label"多语言配置" style"width:700px;" prop"validTanleHead"><el-input style"width: 180px" placeholder"请…

前端-动画库Lottie 3分钟学会使用

目录 1. Lottie地址 2. 使用html实操 3. 也可以选择其他的语言 1. Lottie地址 LottieFiles: Download Free lightweight animations for website & apps.Effortlessly bring the smallest, free, ready-to-use motion graphics for the web, app, social, and designs.…

汇编环境搭建

学习视频 将MASM所在目录 指定为C盘

Flutter:打包apk,详细图文介绍(一)

困扰了一天&#xff0c;终于能正常打包apk安装了&#xff0c;记录下打包的流程。建议参考我这篇文章时&#xff0c;同时看下官网的构建说明。 官网构建并发布 Android 应用详情 1、AS创建Flutter项目 2、cmd执行命令 生成一个sunluyi.jks的文件&#xff0c;可以自行把sunluyi替…

单个变量a的妙用

一道清华大学复试上机题 问题&#xff1a;为什么只需要定义一个整数变量a&#xff0c;而不是定义一个数组a[]&#xff1f; 回答 在这段代码中&#xff0c;只需要定义一个整数变量 a&#xff0c;而不是一个数组 a[]&#xff0c;是因为程序的逻辑是逐个处理输入的整数并立即输出…

【YOLOv8模型网络结构图理解】

YOLOv8模型网络结构图理解 1 YOLOv8的yaml配置文件2 YOLOv8网络结构2.1 Conv2.2 C3与C2f2.3 SPPF2.4 Upsample2.5 Detect层 1 YOLOv8的yaml配置文件 YOLOv8的配置文件定义了模型的关键参数和结构&#xff0c;包括类别数、模型尺寸、骨干&#xff08;backbone&#xff09;和头部…

手机租赁平台开发助力智能设备租赁新模式

内容概要 手机租赁平台开发&#xff0c;简单说就是让你用得起高大上的智能设备&#xff0c;不管是最新款的手机、平板&#xff0c;还是那些炫酷的智能耳机&#xff0c;这个平台应有尽有。想要体验但又不希望花大钱&#xff1f;那你就找对地方了&#xff01;通过灵活的租赁方案…

「Mac畅玩鸿蒙与硬件48」UI互动应用篇25 - 简易购物车功能实现

本篇教程将带你实现一个简易购物车功能。通过使用接口定义商品结构&#xff0c;我们将创建一个动态购物车&#xff0c;支持商品的添加、移除以及实时总价计算。 关键词 UI互动应用接口定义购物车功能动态计算商品管理列表操作 一、功能说明 简易购物车功能包含以下交互&#…

Datawhale AI冬令营(第二期)动手学AI Agent task2--学Prompt工程,优化Agent效果

目录 如何写好Prompt&#xff1f; 工具包神器1&#xff1a;Prompt框架——CO-STAR 框架 工具包神器2&#xff1a;Prompt结构优化 工具包神器3&#xff1a;引入案例 案例&#xff1a;构建虚拟女友小冰 1. 按照 CO-STAR框架 梳理目标 2. 撰写Prompt 3. 制作对话生成应用&…