从零开始: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 是一种非常强大的版本控制系统,它可以帮助您在多人协作开发项目中更好地管理代码版本,并确保每个团队成员都能及时地获取最新的代码更改。在使用 Git 进行版本控制之前,您需要先进行一些设置,以确保您的代码能够顺利地与远程仓…...
Docker compose部署Golang服务
Docker Compose 部署 在使用docker部署时,除了使用--link的方式来关联容器之外,还可以使用 docker compose 运行多个容器。 本文以项目:https://github.com/johncxf/go-api 为例。 定义 Dockerfile 我这里用于区分默认 Dockerfile 文件&a…...
Day36 435无重叠区间 763划分字母区间
435 无重叠区间 给定一个区间的集合,找到需要移除区间的最小数量,使剩余区间互不重叠。 注意: 可以认为区间的终点总是大于它的起点。 区间 [1,2] 和 [2,3] 的边界相互“接触”,但没有相互重叠。 本题与上一题类似: 如果按照左…...
【Servlet】如何编写第一个Servlet程序
个人主页:兜里有颗棉花糖 欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 兜里有颗棉花糖 原创 收录于专栏【Servlet】 本专栏旨在分享学习Servlet的一点学习心得,欢迎大家在评论区交流讨论💌 Servlet是Java编写的服务器端…...
读懂比特币—bitcoin代码分析(五)
今天的代码分析主要是 bitcoin/src/init.cpp 文件中的三个函数:AppInitSanityChecks、AppInitLockDataDirectory、AppInitInterfaces,下面我们来说明这三个函数是用来干什么的,并逐行解读函数代码,先贴出源代码如下: …...
uniapp使用uQRCode插件生成二维码的简单使用
最近在找移动端绘制二维码的问题 ,直接上代码 下载 weapp-qrcode.js(可以通过npm install weapp-qrcode --save 下载,之后把它父子到untils目录下) npm install weapp-qrcode --save在组件页面使用 <canvas id"couponQrcode" canvas-id&qu…...
【寒假每日一题·2024】AcWing 4965. 三国游戏(补)
文章目录 一、题目1、原题链接2、题目描述 二、解题报告1、思路分析2、时间复杂度3、代码详解 一、题目 1、原题链接 4965. 三国游戏 2、题目描述 二、解题报告 1、思路分析 思路参考y总:y总讲解视频 (1)题目中的获胜情况分为三种ÿ…...
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文件内容: # 数据库文件存储位置 dbpa…...
整数反转算法(leetcode第7题)
题目描述: 给你一个 32 位的有符号整数 x ,返回将 x 中的数字部分反转后的结果。如果反转后整数超过 32 位的有符号整数的范围 [−231, 231 − 1] ,就返回 0。假设环境不允许存储 64 位整数(有符号或无符号)。示例 1…...
微信小程序(十)表单组件(入门)
注释很详细,直接上代码 上一篇 新增内容: 1.type 属性指定表单类型 2.placeholder 属性指定输入框为空时的占位文字 源码: 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比较好?
哈喽大家好,我是咕噜美乐蒂,很高兴又见面啦!今天我们来了解一下什么是IDE以及新手应该如何选择IDE比较合适。 一、什么是IDE? IDE(Integrated Development Environment,集成开发环境)是一种软…...
【数据库学习】pg安装与运维
1,安装与配置 #安装 yum install https:....rpm1)安装目录 bin目录:二进制可执行文件目录,此目录下有postgres、psql等可执行程序;pg_ctl工具在此目录,可以通过pg_ctl --help查看具体使用。 conf目录&…...
第二篇【传奇开心果短博文系列】Python的OpenCV库技术点案例示例:图像处理
传奇开心果短博文系列 系列短博文目录Python的OpenCV库技术点案例示例短博文系列 博文目录一、项目目标二、第一个示例代码三、第二个示例代码四、第三个示例代码五、第四个示例代码六、第五个示例代码七、知识点归纳总结 系列短博文目录 Python的OpenCV库技术点案例示例短博文…...
【vue oidc-client】invalid_requestRequest Id: 0HN0OOPFRLSF2:00000002
需求:完成统一登录,需要从三方平台跳到我们的平台。 oidc-client报错记录。这个一般是配置信息出错,需要和三方平台进行沟通,一定要把client_id,密钥进行对应; 同时关于此次出错还修改了以下代码ÿ…...
什么是中间人攻击? ssh 连接出现 Host key verification failed 解决方法
文章目录 前言known_hosts 文件是什么文件路径示例 连接出现 Host key verification failedssh-keygen -R [hostname or ip address]删除整个 known_hosts 文件 其它聊聊中间人攻击ssh 如何保证安全?加密流程漏洞在哪里如何避免中间人攻击 个人简介 前言 最近服务器…...
数据结构系统刷题
本文为系统刷leetcode的记录,会记录自己根据代码随想录刷过的leetcode,方便直接点开刷题,时常更新 时间复杂度简记为s 空间复杂度简记为k 数组 704 二分查找 一维二分查找 (1)[left, right] class Solution { publi…...
【RabbitMQ】延迟队列之死信交换机
🎉🎉欢迎来到我的CSDN主页!🎉🎉 🏅我是Java方文山,一个在CSDN分享笔记的博主。📚📚 🌟推荐给大家我的专栏《RabbitMQ实战》。🎯🎯 &am…...
2024交通运输工程与土木建筑工程国际会议(ICTECCE2024)
2024交通运输工程与土木建筑工程国际会议(ICTECCE2024) 会议简介 2024年国际交通工程和土木建筑工程会议(ICTECCE 2024)将在中国杭州举行。ICTECCE 2024致力于为交通工程和土木工程材料领域的学者、工程师和研究人员提供一个大型学术交流平台和双向交流…...
搜索引擎Elasticsearch了解
1.Lucene 是什么? 2.模块介绍 Lucene是什么: 一种高性能,可伸缩的信息搜索(IR)库 在2000年开源,最初由鼎鼎大名的Doug Cutting开发 是基于Java实现的高性能的开源项目 Lucene采用了基于倒排表的设计原理,可以非常高效地实现文本查找,在底层采用了分段的存储模式,使它在读…...
3大核心价值:让你的Markdown文档呈现专业级视觉体验
3大核心价值:让你的Markdown文档呈现专业级视觉体验 【免费下载链接】github-markdown-css The minimal amount of CSS to replicate the GitHub Markdown style 项目地址: https://gitcode.com/gh_mirrors/gi/github-markdown-css 面向开发者与文档创作者的…...
ChatGPT API 支付机制深度解析:从订阅模式到企业级结算方案
1. API调用成本:LLM应用ROI的关键变量 在构建基于大型语言模型(LLM)的应用时,技术决策者往往聚焦于模型性能、响应延迟和功能实现,而容易低估持续运营成本,尤其是API调用成本对投资回报率(ROI&…...
基于Docker的CosyVoice AI开发环境搭建与优化实践
最近在折腾CosyVoice这个语音模型,发现环境配置真是让人头疼。各种Python版本、CUDA驱动、音频库依赖,稍有不慎就报错。特别是团队协作时,每个人的本地环境差异导致“在我机器上能跑”的经典问题频繁出现。经过一番摸索,我最终用D…...
深度学习项目训练环境惊艳效果:同一镜像下AlexNet/VGG/ResNet/EfficientNet对比训练
深度学习项目训练环境惊艳效果:同一镜像下AlexNet/VGG/ResNet/EfficientNet对比训练 你是不是也遇到过这样的烦恼?想复现一个经典的深度学习模型,光是配环境就花了大半天,各种版本冲突、依赖缺失,最后代码还没跑起来&…...
SecGPT-14B开源可部署:无需申请License的国产网络安全大模型本地化方案
SecGPT-14B开源可部署:无需申请License的国产网络安全大模型本地化方案 1. 引言 如果你是网络安全工程师、安全研究员,或者只是对网络安全感兴趣的技术爱好者,最近可能被各种大模型刷屏了。但当你真正想找一个专门用于网络安全领域的模型时…...
告别手动处理!用HyP3+MintPy+ERA5自动化搞定Sentinel-1时序形变分析(保姆级避坑指南)
从零构建Sentinel-1时序形变分析自动化流水线:HyP3MintPyERA5实战手册 当传统InSAR分析流程需要耗费数周时间手动处理数据时,我们如何通过云端服务与开源工具的组合实现效率的指数级提升?本文将揭示一套经过实战检验的自动化解决方案…...
Vivado工程管理神器:TCL脚本一键重建工程(附完整脚本代码)
Vivado工程管理神器:TCL脚本一键重建工程(附完整脚本代码) 在FPGA开发领域,Vivado作为主流开发工具,其工程文件的管理一直是团队协作和版本控制中的痛点。每次更换开发环境或与团队成员共享工程时,传统方法…...
Qwen3.5-4B-Claude-Opus-GGUF入门:Qwen3.5-4B与Claude-4.6能力对齐评估方法
Qwen3.5-4B-Claude-Opus-GGUF入门:Qwen3.5-4B与Claude-4.6能力对齐评估方法 1. 模型概述 Qwen3.5-4B-Claude-4.6-Opus-Reasoning-Distilled-GGUF是一个基于Qwen3.5-4B的推理蒸馏模型,重点强化了结构化分析、分步骤回答、代码与逻辑类问题的处理能力。该…...
ROS2与Python的完美结合:手把手教你创建第一个功能包
ROS2与Python的完美结合:手把手教你创建第一个功能包 在机器人开发领域,ROS2已经成为事实上的标准框架,而Python凭借其简洁易用的特性,成为快速原型开发的首选语言。当这两者相遇,会擦出怎样的火花?本文将带…...
AI智能体开发实战指南:从架构设计到生态拓展
AI智能体开发实战指南:从架构设计到生态拓展 【免费下载链接】ai-agents-for-beginners 这个项目是一个针对初学者的 AI 代理课程,包含 10 个课程,涵盖构建 AI 代理的基础知识。源项目地址:https://github.com/microsoft/ai-agent…...
