从零开始: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使用指南。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【C++】类与对象(上)

我们好像在没接触过编程语言时就听说 C语言时面向过程&#xff0c;而CPP&#xff0c;java…是面向对象&#xff0c; 当时看不懂也不理解&#xff0c;现在看懂了却还是没有理解 本篇文章我们会一起初步认识C的灵魂&#xff1a;类 目录 面向过程与面向对象的初步认识&#xff1…

量子网络是什么

量子网络是基于量子力学规律对量子信息进行存储、处理和传输的物理装置&#xff0c;是实现量子通讯和大规模量子计算的基础。清华大学研究团队利用同种离子的双类型量子比特编码&#xff0c;在国际上首次实现无串扰的量子网络节点&#xff0c;对未来实现量子通讯和大规模量子计…

程序媛的mac修炼手册-- 如何用Python节省WPS会员费

上篇分享了如何用微博爬虫&#xff0c;咱举例爬了女明星江疏影的微博数据。今天就用这些数据&#xff0c;给大家安利一下怎么用Python实现WPS中部分Excel付费功能。 MacOS系统自带的工具&#xff0c;绝大多数都非常顶&#xff0c;除Numbers外。当然&#xff0c;page比起word来&…

gin中使用swagger生成接口文档

想要使用gin-swagger为你的代码自动生成接口文档&#xff0c;一般需要下面三个步骤&#xff1a; 按照swagger要求给接口代码添加声明式注释&#xff0c;具体参照声明式注释格式。使用swag工具扫描代码自动生成API接口文档数据使用gin-swagger渲染在线接口文档页面 第一步&…

QT ui界面修改后不更新

ui界面修改后不更新 在ui界面重新修改布局后&#xff0c;debug模式下发现ui界面没有更新 尝试1&#xff1a;qmake rebuild发现ui界面都没有更新 尝试2&#xff1a; 删除build-XXXX-Desktop_Qt_5_12_6_MSVC2017_64bit-Debug 重新qmake rebuild 界面没有更新 尝试3&…

新能源、新智造、新技术、新未来2024上海国际氢能产业展览会7月魔都开展!

氢能作为一种来源丰富、绿色低碳、应用广泛的二次能源&#xff0c;是实现可再生能源大规模消纳&#xff0c;电网大规模调峰和跨季节、跨地域储能的重要途径&#xff0c;对构建我国新型电力系统和实现碳达峰碳中和目标具有重要意义。 为落实国家关于发展氢能产业的决策部署&…

某顺cookie逆向

目标网站:aHR0cHM6Ly9xLjEwanFrYS5jb20uY24v 这个网站是对cookie进行反爬虫的&#xff0c;可以看到cookie中有一个加密参数v 二、分析参数 可以使用hook方法&#xff0c;来hook住cookie中v生成的位置&#xff0c;可以直接在控制台中输入hook函数 (function () {use strict;v…

编译原理2.3习题 语法制导分析[C++]

图源&#xff1a;文心一言 编译原理习题整理~&#x1f95d;&#x1f95d; 作为初学者的我&#xff0c;这些习题主要用于自我巩固。由于是自学&#xff0c;答案难免有误&#xff0c;非常欢迎各位小伙伴指正与讨论&#xff01;&#x1f44f;&#x1f4a1; 第1版&#xff1a;自…

提取视频中的某一帧画面,留住视频中的美好瞬间

你是否曾经被视频中的某一帧画面深深吸引&#xff0c;却又惋惜于无法将其永久保存&#xff1f;现在&#xff0c;有了我们【媒体梦工厂】&#xff0c;这一遗憾将成为过去&#xff0c;这个软件可以提取视频中的某一帧保存为图片&#xff0c;为你留住那些稍纵即逝的美好。 所需工…

LVDS 两通道总线驱动器——MS2652D

产品简述 MS2652D 是一款低功耗、高数据传输率的两通道 CMOS 差分 LVDS 信号总线驱动芯片&#xff0c;其支持的数据接收率超过 155.5 Mbps (77.7 MHz) 。 MS2652D 将接 TTL/CMOS 输入信号&#xff0c;转换成低压 (425mV) 的差分输出信 号。芯片驱动器还支持三态输出…

PageHelper学习使用

基于mybatis源码和PageHelper源码进行的测试 版本 mybatis3.5.0&#xff0c;pageHelper6.0.0 测试用例 依赖 <dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.15</version> &…

怎么实现抖音引导到微信小程序丨数灵通教你

抖音是一款热门的社交媒体应用&#xff0c;许多用户希望能够通过抖音跳转到微信小程序&#xff0c;以实现更多的引流和推广效果。以下是关于抖音跳转到微信小程序的科普信息&#xff1a; 1.优势和用途&#xff1a;通过抖音跳转到微信小程序可以带来多个优势和用途&#xff1a; …

Redis核心技术与实战【学习笔记】 - 1.Redis为什么高性能

作为键值数据库&#xff0c;Redis 的应用非常广泛&#xff0c;如果你是后端工程师&#xff0c;我猜你出去面试&#xff0c;八成都会被问到与它相关的性能问题。比如说&#xff0c;为了保证数据的可靠性&#xff0c;Redis 需要在磁盘上读写 AOF 和 RDB&#xff0c;但在高并发场景…

CSS3基础知识总结

目录 一、CSS3 边框 1.border-radius&#xff1a;圆角边框 2.box-shadow&#xff1a;添加阴影 3.border-image&#xff1a;图片边框 二、CSS3 渐变 1.线性渐变(Linear Gradients) a.由上到下&#xff08;默认&#xff09; b.从左到右 c.对角 d.使用角度 2.径向渐变(…

在 EggJS 中实现 Redis 上锁

配置环境 下载 Redis Windows 访问 https://github.com/microsoftarchive/redis/releases 选择版本进行下载 - 勾选 [配置到环境变量] - 无脑下一步并安装 命令行执行&#xff1a;redis-cli -v 查看已安装的 Redis 版本&#xff0c;能成功查看就表示安装成功啦~ Mac brew i…

【项目日记(四)】第一层: 线程缓存的具体实现

&#x1f493;博主CSDN主页:杭电码农-NEO&#x1f493;   ⏩专栏分类:项目日记-高并发内存池⏪   &#x1f69a;代码仓库:NEO的学习日记&#x1f69a;   &#x1f339;关注我&#x1faf5;带你做项目   &#x1f51d;&#x1f51d; 开发环境: Visual Studio 2022 项目日…

PHP“引用”漏洞

今日例题&#xff1a; <?php highlight_file(__FILE__); error_reporting(0); include("flag.php"); class just4fun { var $enter; var $secret; } if (isset($_GET[pass])) { $pass $_GET[pass]; $passstr_replace(*,\*,$pass); } $o unser…

Redis(秒杀活动、持久化之RDB、AOF)

目录 秒杀活动 一、测压工具jmete的使用 二、java实现秒杀活动 1、myseckillcontroller 2、先启动pos请求添加商品&#xff0c;再启动jmeter进行压测 Redis持久化 一 、Redis持久化之RDB 1.RDB是什么 2. 备份是如何执行的 3.Fork 4. RDB持久化流程 5. dump.rdb文件 6…

自定义错误页面在Spring Boot中的实现

引言 在SpringBoot中&#xff0c;常用的异常处理有两种&#xff1a;一种是 BasicErrorController&#xff0c;另一种是 ControllerAdvice。BasicErrorController 用于处理非Controller抛出的异常&#xff0c;而ControllerAdvice 用于处理Controller抛出的异常&#xff0c;对于…

安全基础~通用漏洞2

文章目录 知识补充盲注Boolean盲注延时盲注报错注入二次注入 知识补充 盲注常用 if(条件,5,0) #条件成立 返回5 反之 返回0 left(database(),1)&#xff0c;database() #left(a,b)从左侧截取a的前b位 盲注 盲注就是在注入过程中&#xff0c;获取的数据不能回显至前端页面。 …