【JAVA】Git 的基本概念和使用方式

Git是一个开源的分布式版本控制系统,由Linus Torvalds创建,用于有效、高速地处理从小到大的项目版本管理。以下是Git的一些基本概念和使用方式的深入探讨:

基本概念

1. 仓库(Repository)
  • 仓库是Git用来保存你的项目文件和版本历史的地点。
2. 工作区(Working Directory)
  • 工作区是仓库中检查出来的当前版本的一个拷贝,你可以在这个目录下修改文件。
3. 暂存区(Staging Area)
  • 暂存区是一个准备下一次提交的改动的文件列表,通常是一个保存在Git仓库目录中的简单数据库。
4. 提交(Commit)
  • 提交是你将暂存区的改动写入项目历史中的操作。
5. 分支(Branch)
  • 分支是Git中一个非常强大的功能,它允许你从开发主线上分出一个并行的线路,你可以在这个分支上进行开发,而不会影响主线上的代码。
6. 合并(Merge)
  • 合并是将一个分支的改动历史整合到另一个分支上。
7. 回滚(Revert)
  • 回滚是撤销某次提交所做的改动。
8. 远程仓库(Remote Repository)
  • 远程仓库是托管在网络服务器上的仓库,可以多人协作开发。

使用方式

初始化仓库
git init
添加文件到暂存区
git add <file>
提交改动到仓库
git commit -m "commit message"
查看当前分支
git branch
创建并切换到新分支
git checkout -b <branch-name>
切换到已有分支
git checkout <branch-name>
合并分支
git merge <branch-name>
查看当前状态
git status
查看提交历史
git log
回滚到某次提交
git revert <commit-hash>
克隆远程仓库
git clone <repository-url>
添加远程仓库
git remote add <remote-name> <repository-url>
推送到远程仓库
git push <remote-name> <branch-name>
从远程仓库拉取
git pull <remote-name> <branch-name>
解决冲突

当Git无法自动合并改动时,你需要手动解决冲突。Git会标记出有冲突的文件,你编辑这些文件,解决冲突后,使用git add将它们标记为解决冲突,然后进行git commit

高级使用

1. 分支策略
  • GitFlow:一种严格的分支管理策略,适用于大型复杂项目。
  • GitHub Flow:适用于更频繁发布和较小特性开发的项目。
2. 交互式暂存
  • 使用git add -igit add --interactive进行交互式暂存。
3. 变基(Rebase)
  • 使用git rebase将当前分支上的改动应用到另一分支上,使得项目历史更加线性。
4. 标签(Tag)
  • 使用git tag来标记重要的提交,如版本发布点。
5. 子模块(Submodule)
  • 使用子模块可以包含其他Git仓库作为项目的一部分。
6. 钩子(Hooks)
  • Git提供了多种钩子,可以在特定的Git操作发生时自动执行脚本。
7. 配置别名
  • 使用git config配置别名,简化常用命令。

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

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

相关文章

go解析含passphrase的pem秘钥

背景 在编写TLS配置时需要用到需要用到一串包含passphrase的RSA秘钥&#xff0c;本想通过官方库的方式解析使用&#xff0c;但由于安全因素&#xff0c;官方已经禁用了DecryptPEMBlock、EncryptPEMBlock、IsEncryptedPEMBlock等函数&#xff0c;导致无法通过官方库去实现这个需…

Unity 委托与事件、装箱和拆箱

文章目录 前言一、委托与事件1、委托的概念2、委托是什么3、事件是什么 二、装箱和拆箱1、什么是装箱和拆箱2、堆、栈3、应用4、优化 总结 前言 一、委托与事件 1、委托的概念 不知道大家在学习C#之前有没有学习过C/C&#xff0c;在中后期会接触到指针。她不仅能指向变量的地…

FPGA第一篇,FPGA现场可编程门阵列,从0开始掌握可编程硬件开发(FPGA入门指南)

简介&#xff1a;FPGA全称Field-Programmable Gate Array&#xff0c;是一种可编程逻辑器件&#xff0c;它通过可编程的逻辑单元和可编程的连接网络实现了灵活的硬件实现。与固定功能的集成电路&#xff08;ASIC&#xff09;相比&#xff0c;FPGA具有更高的灵活性和可重新配置性…

未授权访问:Redis未授权访问漏洞

目录 1、漏洞原理 2、环境搭建 3、未授权访问 4、利用redis未授权写入weshell 5、利用redis未授权反弹shell 6、利用redis未授权实现免密登录 防御手段 从这篇文章开始我就要开始学习各种未授权访问的知识和相关的实操实验了&#xff0c;一共有好多篇&#xff0c;内容主…

美港通正规炒股市场恒生科指半日跌近2% 大型科技股集体下行

查查配5月7日电 7日,港股主要股指回调。截至午盘,恒生指数跌0.85%,恒生科技指数跌1.98%。 美港通证券以其专业的服务和较低的管理费用在市场中受到不少关注。该平台提供了实盘交易、止盈止损、仓位控制等功能,旨在为投资者提供更为全面的投资体验。 来源:Wind 盘面上,零售、软…

OC5864 0.6A输出 60V输入 500KHZ DCDC降压转换IC

一级代理 技术支持 提供样品测试 Tel&#xff1a;18028786817 简介 OC5864是一款内置功率MOSFET的单片降压型开关模式转换器。OC5864在5.5~60V宽输入电源范围内实现0.6A峰值输出电流&#xff0c;并且具有出色的线电压和负载调整率。 OC5864采用PWM电流模工作模式&#xff0c;…

stm32单片机遇到的问题(持续更新)

flymcu下载问题一直显示连接&#xff0c;实际是连接不上 参考&#xff0c;软件一键下载电路等 使用flymcu下载程序过程中&#xff0c;检测两个地方**&#xff0c;第一&#xff0c;两个boot引脚在下载和硬件运行不同的连接方式** BOOT1x&#xff0c;BOOT00&#xff1a;最常用的模…

kubectl_进阶_网络

网络 容器网络发展到现在&#xff0c;形成了两大阵营&#xff0c;就是 Docker 的 CNM 和 Google、CoreOS、Kuberenetes 主导的 CNI。首先明确一点&#xff0c;CNM 和 CNI 并不是网络实现&#xff0c;他们是网络规范和网络体系&#xff0c;从研发的角度他们就是一堆接口&#x…

RPC 失败。curl 16 Error in the HTTP2 framing layer

报错&#xff1a; (base) hh-virtual-machine:~/work$ git clone https://github.com/yangzongzhuan/RuoYi-Vue3.git 正克隆到 RuoYi-Vue3... error: RPC 失败。curl 16 Error in the HTTP2 framing layer fatal: 在引用列表之后应该有一个 flush 包这个错误通常是由于 Git 在…

sql中的lag()和lead()是什么意思

在SQL中&#xff0c;LAG() 和 LEAD() 是窗口函数&#xff0c;它们用于访问行与其相邻行的数据。这两个函数在进行数据比较和分析时非常有用&#xff0c;尤其是在需要根据行的相对位置进行操作的场景中。 ### LAG() LAG() 函数用于访问当前行的前面的行中的数据。你可以指定你想…

CentOS操作

1.如何修改主机名 方法一&#xff1a; 修改命令&#xff1a;hostnamectl set-hostname 主机名 查看命令&#xff1a;hostname 方法二和方法三都是永久改变主机名&#xff0c;需要密码验证 方法二 修改命令&#xff1a;nmcli general hostname 主机名 查看命令&#xff…

了解 websocket

​ 1. 概念 1、 websocket 是一种双向通行协议。实现了浏览器与服务器全双工通信&#xff0c;能更好的节省服务器资源和带宽并达到实时通讯的目的&#xff1b; 2、websocket连接成功后&#xff0c;只要连接不断开&#xff0c;通信就会一保持着&#xff1b; 3、要打开一个 WebS…

三维点云处理-聚类(下)

接着前一部分数据聚类方法的介绍&#xff0c;由于K-means和GMM方法都是基于欧式距离信息处理的&#xff0c;两者分别以圆形和椭圆形来作为数据的聚类分割方式&#xff0c;这种情况下会导致环形图和月牙图数据分割不准确&#xff0c;因此进一步的介绍一种谱聚类方法&#xff0c;…

感知机导论

综述 每一个算法都是为了解决一类问题&#xff0c;或者说是解决之前算法存在的缺陷而产生的,感知机&#xff0c;在这里就起到了一个很大的作用&#xff0c;它向后续的很多算法暴露出来了很多它存在的缺陷。所以我们后面要学习的很多算法都是在某种程度上解决了感知机暴露出来的…

静态NAT

哈喽&#xff01;各位小伙伴们好久不见&#xff0c;最近由于工作的原因断更了一段时间&#xff0c;不过最近我都会把这些给补上&#xff0c;今天我们来学习一个简单的知识——静态NAT转换。 第一章 什么是NAT技术&#xff1f; 网络地址转换技术NAT&#xff08;Networ…

致远M3 log 敏感信息泄露漏洞

文章目录 免责漏洞描述漏洞原理影响版本漏洞复现修复方法 免责 只为学习与交流&#xff0c;若利用做一切违法乱纪的事与本人无关 漏洞描述 致远M3是一个企业移动业务管理平台&#xff0c;全面覆盖各种工作场景&#xff0c;通过智能化的办公和业务场景融合&#xff0c;为企业…

【数据库原理及应用】期末复习汇总高校期末真题试卷07

试卷 一、填空题&#xff08;每空1分&#xff0c;共10分&#xff09; 1.数据库管理系统在外模式、模式和内模式这三级模式之间提供了两层映象&#xff0c;其中 映象保证了数据的逻辑独立性。 2. 数据模型通常由 、数据操作和完整性约束三部分组…

未来几年,还是要掌握真正的技术

我看到某些人很鼓吹不要精心学技术&#xff0c;要学管理&#xff0c;学系统化的思想方式。这都是在鼓吹成功的玄学&#xff0c;其实成功的人都具备偶然性&#xff0c;换而言之&#xff0c;再给他一次机会&#xff0c;他不见得会赚取这么多的财富。过去几十年&#xff0c;经济高…

SAP FI 常用表

GL部分&#xff1a; FAGLFLEXT 新总账汇总表 GLT0 旧总帐汇总表 SKA1 总账科目主记录 (科目表) 科目表层数据 SKAT 总帐科目主记录&#xff08;科目表&#xff1a;说明&#xff09; 包括语言代码 SKB1 总帐科目主记录 (公司代码) 公司代码层数据 BKPF…

代码随想录:二分查找相关题目推荐(35、34)

35.搜索插入位置 题目 给定一个排序数组和一个目标值&#xff0c;在数组中找到目标值&#xff0c;并返回其索引。如果目标值不存在于数组中&#xff0c;返回它将会被按顺序插入的位置。 请必须使用时间复杂度为 O(log n) 的算法。 示例 1: 输入: nums [1,3,5,6], target …