Git版本工具学习

目录

        • 版本控制
        • git配置
        • 工作区域
        • 文件状态
        • git对象模型
        • 基础命令
        • .gitignore忽略文件
        • IDEA集成Git

版本控制

本地版本控制:在本地记录每一次版本更新。

集中版本控制:版本数据都保存在单一服务器,不联网就看不到版本信息。SVN

分布式版本控制:所有的版本信息都同步到本地的每个用户,可以离线在本地提交,只需在联网时push。Git

SVN与Git的区别:

  • SVN 是集中式的;Git 是分布式的
  • SVN 的分支操作成本(创建/删除/合并)比 Git 高
  • SVN 是存储变更差异;Git 是存储文件快照
  • SVN必须联网操作,只有服务器上的版本控制;Git支持离线操作,有本地的版本控制
git配置

1)git\mingw64\etc\gitconfig ,–system系统级

2)C:\Users\用户\.gitconfig ,–global全局

Git branch 获取分支列表 ,列表保存到refs/heads/master 下面。

git config -l,配置清单

git config --system --list,系统配置

git config --global --list,全局配置(用户配置)

安装好git后,设置用户名和邮箱(必要):

git config --global user.name "xxx"
git config --global user.email "xxx@qq.com"

配置ssh公私钥连接远程仓库:

在c:/Users/用户/.ssh下打开git bash,运行ssh-kengen生成公私钥,将pub公钥粘贴到远程仓库配置中。

工作区域

git本地有三个工作区域:工作目录、暂存区(stage/index)、资源库(repository)、远程仓库(remote repository)。

工作区:平时写代码项目文件的目录。

index/stage:存放提交的文件列表信息的文件。

Local R本地仓库:存放提交的所有版本信息,HEAD总是指向当前分支。

Remote:托管代码的远程服务器。

git

文件状态

untracked:未加入到本地库中,不参与版本控制,使用git add变为staged状态

unmodify:文件已入库,未修改。变为modified文件或git rm移除版本库变为untracked状态。

modified:文件已修改。通过git add变为staged状态,或通过git checkout放弃修改回到unmodify状态。

staged:暂存状态。执行git commit提交到版本库中,文件变为unmodify状态,执行git reset HEAD filename取消暂存,文件变为modified状态。

git对象模型

在git系统中有四种尅对象:

commit:指向一个tree,纪录了文件操作,作者,提交者信息;

tree:对象关系树,管理tree和blob的关系;

blob:保存文件内容;

tag:标记提交。

基础命令

git init,本地创建一个新的项目。

git clone [url],克隆远程仓库上的项目代码。

git rm/mv [file],删除移动文件

git status [xx],查看文件状态。

git commit -m xxx,提交暂存区中的内容到本地仓库,-v提交时显示diff信息。

git branch,查看本地分支,-r查看远程,-d [name]删除分支,-rd删除远程分支

# 新建一个分支,与指定的远程分支建立追踪关系
$ git branch --track [branch] [remote-branch]

git merge [branch],合并分支到当前分支。

git checkout [branch]或git switch,切换到指定分支。

git checkout [file],恢复暂存区文件到工作区。

git log,显示当前分支版本历史,-S [key]根据关键词搜索提交历史,–follow [file]显示某文件的版本历史,–oneline简洁显示。

git shortlog -sn,显示所有提交过的用户。

git blame [file],显示文件被什么人什么时间修改。

git diff,显示工作区和暂存区的差异。

git show [commit],显示某次提交的时间和内容变化。

git fetch [remote],下载远程仓库变动到本地版本库。

git remote -v,显示所有远程仓库,add添加仓库,remove删除。

git pull [remote] [branch],取回远程仓库分支的变化并与本地合并。

git push [remote] [branch],推送本地分支到远程仓库。

master分支主要用于发布新版本,常用工作分支使用dev等分支。

推送失败,因为最新提交和你试图推送的提交有冲突。先用git pull把最新提交从origin/dev抓下来,然后在本地合并,解决冲突,再推送。git pull也失败了,原因是没有指定本地dev分支与远程origin/dev分支的链接,根据提示,设置dev和origin/dev的链接。

git branch --set-upstream-to=origin/dev dev

这回git pull成功,但是合并有冲突,需要手动解决,解决后提交,再push。

.gitignore忽略文件

在目录下创建.gitignore文件,将某些文件排除在版本控制外。

#:注释。

tmp/*.txt:忽略tmp目录所有以.txt结尾的文件,不包括tmp/d/*.txt

!:除了这个文件外忽略所有

/tmp:忽略除tmp文件夹外的其他文件

tmp/:忽略tmp目录下的所有文件

IDEA集成Git

将所有克隆下来的git项目或新创建的git项目文件拷贝到IDEA项目中即可,或在IDEA下载git插件。

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

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

相关文章

虚函数与纯虚函数有什么区别?

总的来说有两点区别: 1.虚函数的作用主要是矫正指针(口语化的说法) 2.虚函数不一定要重新定义,纯虚函数一定要定义(口语化的说法) 1). 虚函数的作用主要是矫正指针,使得基类的指针…

w7安装高版本nodejs

Win7系统可直接安装的最高nodejs版本为13.14,以为要换系统了,不过,网上找到了方法可以安装高版本 我是配置好环境变量后开始操作的(因为之前试了其他方法,没成功,环境变量就留下了) 新建变量NO…

Java中常用的集合及方法(3)

1、List(接上级--常用方法示例补充) 1.4 常用的方法 1.4.2 LinkedList(JDK8) LinkedList是Java中一个实现了List接口和Deque接口的类,它采用链表结构存储数据,支持高效的插入和删除操作。 LinkedList中…

3647. 惠民工程,并查集

市政府“惠民工程”的目标是在全市 n 个居民点间之架设煤气管道(但不一定有直接的管道相连,只要能间接通过管道可达即可)。很显然最多可架设 n(n−1)/2 条管道,然而实际上要连通 n 个居民点只需架设 n−1 条管道就可以了。现请你编…

win10阿里云实现内网穿透#frp

win10&阿里云实现内网穿透#frp 文章目录 win10&阿里云实现内网穿透#frp一、什么是内网穿透?下载frp 二、云服务端部署frps三、本地部署frpc 一、什么是内网穿透? 内网穿透是一种网络技术,它允许外部网络用户通过互联网访问局域网&am…

【Java核心能力】RateLimiter 限流底层原理解析

欢迎关注公众号(通过文章导读关注:【11来了】),及时收到 AI 前沿项目工具及新技术的推送! 在我后台回复 「资料」 可领取编程高频电子书! 在我后台回复「面试」可领取硬核面试笔记! 文章导读地址…

第89篇:方程式工具包远程溢出漏洞图形界面版V0.3(内置永恒之蓝、永恒冠军、永恒浪漫等)...

Part1 前言 大家好,我是ABC_123。我从年前到现在,一直在整理曾经写过的红队工具,逐步把自己认为比较好用的原创工具发出来给大家用一用,方便大家在日常的攻防比赛、红队评估项目中解放双手,节省时间精力和体力。本期给…

C语言实战——扫雷游戏

目录 1. 扫雷游戏分析和设计2.扫雷游戏的代码实现 1. 扫雷游戏分析和设计 1.1扫雷游戏的功能说明 使用控制台实现经典的扫雷游戏游戏可以通过菜单实现继续玩或者退出游戏扫雷的棋盘是9*9的格子默认随机布置10个雷可以排查雷 如果位置不是雷,就显示周围有几个雷 如果…

mysql 性能优化——磁盘刷脏页性能优化

前言 大家是不是感觉mysql 更新挺快的呀,有没有想过mysql 更新为什么那么快。按道理说,mysql 更新都是先找到这一行数据,然后在去更新。意味着,就有两次磁盘操作,一个是磁盘读,一个是磁盘写。如果真的是这…

ImportError: cannot import name ‘InterpolationMode‘

InterpolationMode 在图像处理库中通常用于指定图像缩放时的插值方法。插值是一种数学方法,在图像大小变化时用于估算新像素位置的像素值。不同的插值方法会影响缩放后图像的质量和外观。 在你提供的 image_transform 函数中,InterpolationMode.BICUBIC…

工业以太网交换机助力电力综合自动化系统卓越运行

随着电力行业不断迈向数字化和自动化时代,电力综合自动化系统逐渐成为实现电网智能化管理的核心。在这一复杂而庞大的系统中,工业以太网交换机扮演着至关重要的角色,连接着各种智能设备,实现数据的快速传输和高效管理,…

c++ 串口通信库

根据资料整理的串口通信库,封装成为了动态库,使用者只需要调用接口即可 使用实例如下: //接受数据 void CSerialPortCommonLibDemoDlg::OnReceive() { char * str NULL; str new char[256]; _port.readAllData(str); CString s…

【Docker安装教程】CentOS 7 上的 Docker 安装与配置

CentOS 7 上的 Docker 安装与配置 前提条件 一台运行CentOS 7的服务器对CentOS有基本的了解和操作经验root用户或具有sudo权限的用户 安装步骤 1. 更新系统软件包 首先,确保你的系统是最新的。这有助于避免安装过程中的兼容性问题。 sudo yum update -y2. 安装…

基于SpringBoo的火车订票管理系统(程序+文档+数据库)

** 🍅点赞收藏关注 → 私信领取本源代码、数据库🍅 本人在Java毕业设计领域有多年的经验,陆续会更新更多优质的Java实战项目,希望你能有所收获,少走一些弯路。🍅关注我不迷路🍅** 一、研究背景…

harmonyos arkts 开发商品页面

1.结果展示 2. 实现分层组件 1.1 实现搜索栏 1.2 代码 这段代码是一个构建搜索框组件的方法,具体功能包括: - 创建一个Search组件,设置初始值为this.keyword,placeholder为请输入书名... - 添加一个搜索按钮,并设置…

【雷达相机外参标定】direct_visual_lidar_calibration安装

direct_visual_lidar_calibration安装 主页安装ubuntupclOpenCVceres其他依赖fmtdirect_visual_lidar_calibration 标定雷达和相机时使用direct_visual_lidar_calibration。 主页 https://github.com/koide3/direct_visual_lidar_calibration?tabreadme-ov-filehttps://koid…

MYX Finance 确认出席 Hack.Summit() 2024 区块链开发者大会

🎉MYX Finance 确认出席 Hack.Summit() 2024 区块链开发者大会🚀 🌟 激动人心的消息!我们非常荣幸地宣布,MYX Finance 将出席由Hack VC主办,AltLayer和Berachain协办,携手Solana、The Graph、Bl…

Linux/Ubuntu/Debian基本命令:光标移动命令

Linux系统真的超级好用,免费,有很多开源且功能强大的软件。尤其是Ubuntu,真的可以拯救十年前的老电脑。从今天开始我将做一个Linux的推广者,推广普及Linux基础。 光标移动命令对于在终端(Terminal)内有效导…

【经管数据-更新】华证ESG评级得分数据(2009-2023年)

一、数据说明 参考《经济研究》中方先明(2023)的做法,将华证ESG评级进行赋值,指标包含C、CC、CCC、B、BB、BBB、A、AA、AAA共9个等级,将上市公司ESG 等级从低到高分别赋值为1至9 二、数据来源:世界银行&am…

SPI读取TLE5012B编码器角度数据_ACM32G103

买到一个带编码器的电机,卖家留出来读取编码器数据的接口有SPI 具体的原理图如下: P2标注的是SPI的接口,其中MISO和MOSI是硬件连接到一起的 使用ACM32G103的硬件SPI2去读取其角度数据 原理大概如下: 1、先发送读取数据的指令&…