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

从零开始:Git 上传与使用指南

Git 是一种非常强大的版本控制系统,它可以帮助您在多人协作开发项目中更好地管理代码版本,并确保每个团队成员都能及时地获取最新的代码更改。在使用 Git 进行版本控制之前,您需要先进行一些设置,以确保您的代码能够顺利地与远程仓库同步。


一:安装 Git:

首先,您需要确保您的计算机上已经安装了 Git。

(然后打开CMD,看一下是否下载成功)

二:创建仓库

在您的本地计算机上创建一个新的文件夹,作为您的代码仓库。

在命令行中进入该文件夹(或者是在文件夹中右击可以看到),并运行以下命令初始化一个新的 Git 仓库:

git init

这将创建一个名为 ".git" 的子文件夹,其中包含 Git 所需的所有元数据和配置文件,如下图:

三: 添加文件

使用以下命令将文件添加到 Git 的跟踪列表中:

git add <file>

一般都是下面这个全部上传:

git add .

四:提交更改(注释)

当您对文件进行了更改并希望将它们提交到仓库中时,请运行以下命令:

git commit -m "Commit message"

这将创建一个新的提交,并将您的更改保存在本地仓库中。

五:推送到远程仓库

运行以下命令来添加远程仓库:

git remote add origin <URL>
其中,<URL> 是远程仓库的 URL。
例如,如果您要将代码推送到 GitHub 上,可以使用类似以下命令的 URL:
git remote add origin https://github.com/username/repository.git

然后,使用以下命令将您的本地更改推送到远程仓库:

git push -u origin master

这将把您的本地分支推送到远程仓库的 master(main) 分支上。如果您使用的是其他分支,请相应地更改分支名称。第一次推送时,您还需要使用 "-u" 或 "--set-upstream" 选项来设置本地分支跟踪远程分支。以后您只需使用以下命令即可推送更改:

git push origin <branch-name>

六:拉取最新代码

从远程仓库拉取最新的代码更改时,用以下命令:

git pull origin <branch-name>

这将从远程仓库的指定分支拉取最新的代码更改,并将其合并到您的本地分支中。

七:解决冲突

当您尝试拉取最新的代码更改时,如果本地分支和远程分支之间存在冲突,Git 会停止合并过程并显示冲突的文件。您需要手动编辑这些文件,解决冲突,并将更改提交到本地仓库。解决冲突后,您可以使用以下命令将更改推送到远程仓库:

git push origin <branch-name>

允许合并不相关的历史

git pull origin main --allow-unrelated-histories

八:查看提交历史

要查看您的提交历史记录,可以使用以下命令:

git log

您还可以使用以下命令来查看更详细的提交历史记录:(包括分支和标签信息)

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

九:分支管理

Git 允许您创建和管理多个分支。要创建一个新分支,请使用以下命令:

git branch <branch-name>

要切换到新分支,用以下命令:

git checkout <branch-name>

要合并分支,用以下命令:

git merge <branch-name>

 十:标签管理

Git 还允许您为特定的提交添加标签。要创建一个标签,请使用以下命令:

(<tag-name> 是标签的名称,<commit-hash> 是提交的哈希值。)

git tag <tag-name> <commit-hash>

要将标签推送到远程仓库,请使用以下命令:

git push origin <tag-name>

配置和使用 Git 

Git 钩子是 Git 仓库中的一种机制,可以在特定事件发生时触发自定义脚本。例如,您可以在 Git 钩子的 pre-commit 事件中运行代码检查工具,以确保代码质量。要配置 Git 钩子,请进入您的 Git 仓库的根目录,并创建一个名为 ".git/hooks" 的文件夹(如果尚不存在)。然后,在该文件夹中创建一个以钩子事件命名的脚本文件,例如 "pre-commit"。在脚本文件中,您可以编写您想要在相应事件发生时执行的命令或脚本。确保脚本文件具有可执行权限。

自定义 Git 命令

如果您经常使用某些 Git 命令,您可以创建自定义 Git 命令来简化工作流程。在您的 Git 仓库的根目录下创建一个名为 ".git/hooks/custom" 的文件夹(如果尚不存在)。然后,在该文件夹中创建一个以自定义命令命名的脚本文件。在脚本文件中,您可以编写您想要执行的 Git 命令。例如,您可以创建一个名为 "git-sync" 的自定义命令,用于将本地更改推送到远程仓库并拉取最新代码。

通过学习本文,您将能够熟练掌握Git的基本操作,并能够在多人协作开发项目中更好地管理代码版本,确保代码的质量和可追溯性。无论是对于初学者还是有一定经验的开发者,本文都是一个不可或缺的Git使用指南。

相关文章:

从零开始:Git 上传与使用指南

Git 是一种非常强大的版本控制系统&#xff0c;它可以帮助您在多人协作开发项目中更好地管理代码版本&#xff0c;并确保每个团队成员都能及时地获取最新的代码更改。在使用 Git 进行版本控制之前&#xff0c;您需要先进行一些设置&#xff0c;以确保您的代码能够顺利地与远程仓…...

Docker compose部署Golang服务

Docker Compose 部署 在使用docker部署时&#xff0c;除了使用--link的方式来关联容器之外&#xff0c;还可以使用 docker compose 运行多个容器。 本文以项目&#xff1a;https://github.com/johncxf/go-api 为例。 定义 Dockerfile 我这里用于区分默认 Dockerfile 文件&a…...

Day36 435无重叠区间 763划分字母区间

435 无重叠区间 给定一个区间的集合&#xff0c;找到需要移除区间的最小数量&#xff0c;使剩余区间互不重叠。 注意: 可以认为区间的终点总是大于它的起点。 区间 [1,2] 和 [2,3] 的边界相互“接触”&#xff0c;但没有相互重叠。 本题与上一题类似&#xff1a; 如果按照左…...

【Servlet】如何编写第一个Servlet程序

个人主页&#xff1a;兜里有颗棉花糖 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 兜里有颗棉花糖 原创 收录于专栏【Servlet】 本专栏旨在分享学习Servlet的一点学习心得&#xff0c;欢迎大家在评论区交流讨论&#x1f48c; Servlet是Java编写的服务器端…...

读懂比特币—bitcoin代码分析(五)

今天的代码分析主要是 bitcoin/src/init.cpp 文件中的三个函数&#xff1a;AppInitSanityChecks、AppInitLockDataDirectory、AppInitInterfaces&#xff0c;下面我们来说明这三个函数是用来干什么的&#xff0c;并逐行解读函数代码&#xff0c;先贴出源代码如下&#xff1a; …...

uniapp使用uQRCode插件生成二维码的简单使用

最近在找移动端绘制二维码的问题 &#xff0c;直接上代码 下载 weapp-qrcode.js(可以通过npm install weapp-qrcode --save 下载,之后把它父子到untils目录下&#xff09; npm install weapp-qrcode --save在组件页面使用 <canvas id"couponQrcode" canvas-id&qu…...

【寒假每日一题·2024】AcWing 4965. 三国游戏(补)

文章目录 一、题目1、原题链接2、题目描述 二、解题报告1、思路分析2、时间复杂度3、代码详解 一、题目 1、原题链接 4965. 三国游戏 2、题目描述 二、解题报告 1、思路分析 思路参考y总&#xff1a;y总讲解视频 &#xff08;1&#xff09;题目中的获胜情况分为三种&#xff…...

docker 安装mongodb 数据库

1.拉取mongodb镜像 docker pull mongo2.创建文件夹 mkdir -p /home/mongo/conf/ mkdir -p /home/mongo/data/ mkdir -p /home/mongo/logs/3.新增mongod.conf文件 cd /home/mongo/conf && vi mongod.confmongod.conf文件内容&#xff1a; # 数据库文件存储位置 dbpa…...

整数反转算法(leetcode第7题)

题目描述&#xff1a; 给你一个 32 位的有符号整数 x &#xff0c;返回将 x 中的数字部分反转后的结果。如果反转后整数超过 32 位的有符号整数的范围 [−231, 231 − 1] &#xff0c;就返回 0。假设环境不允许存储 64 位整数&#xff08;有符号或无符号&#xff09;。示例 1…...

微信小程序(十)表单组件(入门)

注释很详细&#xff0c;直接上代码 上一篇 新增内容&#xff1a; 1.type 属性指定表单类型 2.placeholder 属性指定输入框为空时的占位文字 源码&#xff1a; form.wxml <!-- 提前准备好的布局结构代码 --> <view class"register"><view class"…...

xcode 设置 ios苹果图标,为Flutter应用程序配置iOS图标

图标设置 1,根据图片构建各类尺寸的图标2.xcode打开ios文件3.xcode设置图标4.打包提交审核,即可(打包教程可通过我的主页查找) 1,根据图片构建各类尺寸的图标 工具网址:https://icon.wuruihong.com/ 下载之后文件目录如下 拷贝到项目的ios\Runner\Assets.xcassets\AppIcon.ap…...

什么是IDE?新手用哪个IDE比较好?

哈喽大家好&#xff0c;我是咕噜美乐蒂&#xff0c;很高兴又见面啦&#xff01;今天我们来了解一下什么是IDE以及新手应该如何选择IDE比较合适。 一、什么是IDE&#xff1f; IDE&#xff08;Integrated Development Environment&#xff0c;集成开发环境&#xff09;是一种软…...

【数据库学习】pg安装与运维

1&#xff0c;安装与配置 #安装 yum install https:....rpm1&#xff09;安装目录 bin目录&#xff1a;二进制可执行文件目录&#xff0c;此目录下有postgres、psql等可执行程序&#xff1b;pg_ctl工具在此目录&#xff0c;可以通过pg_ctl --help查看具体使用。 conf目录&…...

第二篇【传奇开心果短博文系列】Python的OpenCV库技术点案例示例:图像处理

传奇开心果短博文系列 系列短博文目录Python的OpenCV库技术点案例示例短博文系列 博文目录一、项目目标二、第一个示例代码三、第二个示例代码四、第三个示例代码五、第四个示例代码六、第五个示例代码七、知识点归纳总结 系列短博文目录 Python的OpenCV库技术点案例示例短博文…...

【vue oidc-client】invalid_requestRequest Id: 0HN0OOPFRLSF2:00000002

需求&#xff1a;完成统一登录&#xff0c;需要从三方平台跳到我们的平台。 oidc-client报错记录。这个一般是配置信息出错&#xff0c;需要和三方平台进行沟通&#xff0c;一定要把client_id&#xff0c;密钥进行对应&#xff1b; 同时关于此次出错还修改了以下代码&#xff…...

什么是中间人攻击? ssh 连接出现 Host key verification failed 解决方法

文章目录 前言known_hosts 文件是什么文件路径示例 连接出现 Host key verification failedssh-keygen -R [hostname or ip address]删除整个 known_hosts 文件 其它聊聊中间人攻击ssh 如何保证安全&#xff1f;加密流程漏洞在哪里如何避免中间人攻击 个人简介 前言 最近服务器…...

数据结构系统刷题

本文为系统刷leetcode的记录&#xff0c;会记录自己根据代码随想录刷过的leetcode&#xff0c;方便直接点开刷题&#xff0c;时常更新 时间复杂度简记为s 空间复杂度简记为k 数组 704 二分查找 一维二分查找 &#xff08;1&#xff09;[left, right] class Solution { publi…...

【RabbitMQ】延迟队列之死信交换机

&#x1f389;&#x1f389;欢迎来到我的CSDN主页&#xff01;&#x1f389;&#x1f389; &#x1f3c5;我是Java方文山&#xff0c;一个在CSDN分享笔记的博主。&#x1f4da;&#x1f4da; &#x1f31f;推荐给大家我的专栏《RabbitMQ实战》。&#x1f3af;&#x1f3af; &am…...

2024交通运输工程与土木建筑工程国际会议(ICTECCE2024)

2024交通运输工程与土木建筑工程国际会议(ICTECCE2024) 会议简介 2024年国际交通工程和土木建筑工程会议&#xff08;ICTECCE 2024&#xff09;将在中国杭州举行。ICTECCE 2024致力于为交通工程和土木工程材料领域的学者、工程师和研究人员提供一个大型学术交流平台和双向交流…...

搜索引擎Elasticsearch了解

1.Lucene 是什么? 2.模块介绍 Lucene是什么: 一种高性能,可伸缩的信息搜索(IR)库 在2000年开源,最初由鼎鼎大名的Doug Cutting开发 是基于Java实现的高性能的开源项目 Lucene采用了基于倒排表的设计原理,可以非常高效地实现文本查找,在底层采用了分段的存储模式,使它在读…...

变环境温度下18640电池充放电数据集:全工况、高精度、定价高

变环境温度下的18640充放电数据&#xff0c;我们常见的充放电数据一般都是恒定环境温度的&#xff0c;近一两年开始有变环境温度的实验设计&#xff0c;可以作为一个highlight加以分析&#xff0c;数据集介绍翻译如图&#xff0c;有电压电流脉冲&#xff0c;FUDS&#xff0c;US…...

RAG技术新篇章:Modular RAG模块化架构如何引爆效率与效果?

本文深入解析了RAG技术的演进历程&#xff0c;从最初的Naive RAG到Advanced RAG&#xff0c;再到如今的Modular RAG&#xff0c;阐述了三者间的继承与发展关系。Modular RAG通过模块化设计和智能编排&#xff0c;实现了更高的灵活性和可扩展性。其核心在于Orchestration编排模块…...

达摩院智能客服人工智能训练师实战:从模型训练到生产部署的全链路优化

在智能客服系统的开发过程中&#xff0c;我们常常面临一个核心矛盾&#xff1a;业务方希望模型能快速迭代、精准理解用户意图&#xff0c;而技术团队则受困于漫长的训练周期、复杂的多轮对话逻辑以及繁琐的生产部署流程。传统的自建训练环境&#xff0c;从数据清洗、特征工程到…...

自定义游戏环境:开源启动器PCL2-CE的多场景解决方案

自定义游戏环境&#xff1a;开源启动器PCL2-CE的多场景解决方案 【免费下载链接】PCL-CE PCL2 社区版&#xff0c;可体验上游暂未合并的功能 项目地址: https://gitcode.com/gh_mirrors/pc/PCL-CE PCL2-CE社区版作为一款开源的Minecraft启动工具&#xff0c;通过模块化设…...

沉浸推理的线上聚会:线上剧本杀APP的功能设计

当好友散落在不同的城市&#xff0c;想要围坐一桌来一场酣畅淋漓的推理游戏似乎成了奢望。线上剧本杀APP的出现&#xff0c;打破了空间的限制&#xff0c;让热爱推理与角色扮演的人们能够在线上相聚&#xff0c;共同沉浸在一个个精心编织的故事里。以下从功能体验的角度&#x…...

为什么你的Polars清洗比Pandas还慢?3步定位CPU缓存未对齐、SIMD未启用、线程池饥饿这3大隐形杀手

第一章&#xff1a;Polars 2.0 大规模数据清洗技巧 性能调优指南Polars 2.0 引入了全新的执行引擎与内存管理机制&#xff0c;显著提升了大规模数据清洗场景下的吞吐量与低延迟响应能力。相比 Pandas&#xff0c;其在 10GB 数据集上的列式过滤、字符串标准化与缺失值插补操作平…...

Multisim新手必看:5分钟搞定稳压二极管仿真实验(附限流电阻计算技巧)

Multisim新手必看&#xff1a;5分钟搞定稳压二极管仿真实验&#xff08;附限流电阻计算技巧&#xff09; 在电子工程的学习和实践中&#xff0c;稳压二极管是一个基础但至关重要的元件。它能将电压稳定在特定值&#xff0c;广泛应用于电源电路、保护电路等场景。对于初学者来说…...

别再自己造轮子了!Spring Boot项目集成sensitive-word库实现敏感词过滤(附完整配置流程)

Spring Boot项目快速集成敏感词过滤实战指南 在内容审核日益重要的今天&#xff0c;为应用添加敏感词过滤功能已成为刚需。本文将带你绕过底层算法实现的复杂环节&#xff0c;直接采用成熟的sensitive-word库&#xff0c;在Spring Boot项目中快速搭建高性能的敏感词过滤系统。 …...

高效PDF处理:PDF补丁丁的全场景应用指南

高效PDF处理&#xff1a;PDF补丁丁的全场景应用指南 【免费下载链接】PDFPatcher PDF补丁丁——PDF工具箱&#xff0c;可以编辑书签、剪裁旋转页面、解除限制、提取或合并文档&#xff0c;探查文档结构&#xff0c;提取图片、转成图片等等 项目地址: https://gitcode.com/Git…...

使用GitHub管理口罩检测开源项目

使用GitHub管理口罩检测开源项目 1. 引言 当你开始一个口罩检测开源项目时&#xff0c;如何高效地管理代码、协作开发和自动化流程就成了关键问题。GitHub作为全球最大的代码托管平台&#xff0c;提供了完整的工具链来支持开源项目的全生命周期管理。 我曾经参与过多个计算机…...