Git基本使用教程(学习记录)

news2025/1/18 16:51:56

参考文章链接:
Git教程(超详细,一文秒懂)

RUNOOB Git教程

Git学习记录

1Git概述

1.1版本控制软件功能

  • 版本管理:更新或回退到历史上任何版本,数据备份
  • 共享代码:团队间共享代码,合作开发

1.2svn与git

在这里插入图片描述
上图来自RUNOOB Git教程

  • svn它集中式的版本控制,不能离线工作。git分布式的版本控制,它版本放在用户自己的电脑。
  • svn不支持离线工作,版本全部都放在是中央服务器。如果中央服务器挂了。那么版本全部丢失。
  • git支持离线工作。版本都放用户自己电脑上完成。---- 分布式的版本控制。
  • svn是项目对仓库,git是仓库对仓库。

1.3Git工作机制

在这里插入图片描述上图来自RUNOOB Git教程

图中左侧为工作区,右侧为版本库。在版本库中标记为 “index” 的区域是暂存区(stage/index),标记为 “master” 的是 master 分支所代表的目录树;HEAD是指向当前分支的一个游标(别名),输入命令时可相互替换;objects 标识的区域为 Git 的对象库,实际位于 “.git/objects” 目录下,里面包含了创建的各种对象及内容

  1. 在工作区写代码(**工作区:**就是你在电脑里能看到的目录。)
  2. git add * 临时存储在暂存区(**暂存区:**英文叫 stage 或 index。一般存放在 .git 目录下的 index 文件(.git/index)中,所以我们把暂存区有时也叫作索引(index)),暂存区的目录树被更新,同时工作区修改(或新增)的文件内容被写入到对象库中的一个新的对象中,而该对象的ID被记录在暂存区的文件索引中
  3. git commit -m “ xxx” 提交在本地库并描述(**版本库:**工作区有一个隐藏目录 .git,这个不算工作区,而是 Git 的版本库),暂存区的目录树写到版本库(对象库)中,master 分支会做相应的更新。即 master 指向的目录树就是提交时暂存区的目录树
  4. git push 上传到远程仓库
    在这里插入图片描述上图来自RUNOOB Git教程

1.4Git和代码托管中心

代码托管中心是基于网络服务其的远程代码仓库,简称为远程库

  • 局域网
    • GitLab:自己搭建远程库
    • gogs:极易搭建的自助Git服务
  • 互联网
    • GitHub
    • Gitee

1.5Git安装与配置

#安装
apt-get install libcurl4-gnutls-dev libexpat1-dev gettext \ libz-dev libssl-dev

apt-get install git

git --version
# 输出:git version 1.8.1.2

#配置 gitconfig
# /etc/gitconfig 文件:系统中对所有用户都普遍适用的配置。若使用 git config --system ,读写的就是这个文件
#~/.gitconfig 文件:用户目录下的配置文件只适用于该用户。若使用 git config --global ,读写的就是这个文件
#当前项目的 Git 目录中的配置文件(也就是工作目录中的 .git/config 文件):这里的配置仅仅针对当前项目有效。每一个级别的配置都会覆盖上层的相同配置,所以 .git/config 里的配置会覆盖 /etc/gitconfig 中的同名变量

#下面--global 可以更换为 --system 或不加,意义如上
git config --global user.name "abc"
git config --global user.email abc@qq.com

#查看已有配置信息
git config --list
#输出:user.name=abc user.email=abc@qq.com
# 有时候会看到重复的变量名,那就说明它们来自不同的配置文件(比如 /etc/gitconfig、~/.gitconfig),不过最终 Git 实际采用的是最后一个。

2Git常见命令

git config --global user.name xxx #设置用户名
git config --global user.email xxx #设置用户邮箱
git init #初始化本地库,生成一个 .git 目录,该目录包含了资源的所有元数据,
git init 文件夹名 #指定目录作为Git仓库,会在该目录下生成.git目录,所有Git需要的数据资源都放在该目录

#如果当前目录有几个文件想要纳入版本控制,需要先用git add命令告诉Git开始对这些文件进行跟踪,然后提交:
git add *.c
git add README
git commit -m "初始化项目版本"

git rm #将文件从暂存区和工作区中删除
git mv #移动或重命名工作区文件

git status #查看本地库状态
git add xxx #将xxx文件加入到暂存区
git commit -m "xxx" #提交到本地库并添加日志
git reflog #查看历史记录
git reset --hard 版本号 #版本穿梭
git rm --cached 文件名 #清除暂存区文件
git checkout -- 文件名 #将暂存区中同名文件覆盖到工作区
git checkout 分支名 -- 文件名 #将本地库中同名文件覆盖到暂存区和工作区

git restore #恢复或撤销文件的更改

2.1git status 查看本地库状态

  1. 首次查看,可看到分支,可看到无内容提交
  2. 增加文件后再次查看,文件显示为红色,意味着在工作区,git未追踪该文件

2.2git add 上传工作区文件至本地库

  1. git add xxx
  2. git status 会检测到暂存区有新文件

2.3git commit -m “日志信息” 文件名 提交至本地库

git commit -m 'first commit' hello.txt

2.4修改文件后,文件未被添加到暂存区,需重复上述操作

3历史版本

3.1git reflog 查看提交的版本及日志信息

3.2git log查看完整的提交版本及日志信息

git log [选项] [分支名/提交哈希]

常用的选项包括:

  • -p:显示提交的补丁(具体更改内容)
  • --oneline:以简洁的一行格式显示提交信息
  • --graph:以图形化方式显示分支和合并历史
  • --decorate:显示分支和标签指向的提交
  • --author=<作者>:只显示特定作者的提交
  • --since=<时间>:只显示指定时间之后的提交
  • --until=<时间>:只显示指定时间之前的提交
  • --grep=<模式>:只显示包含指定模式的提交消息
  • --no-merges:不显示合并提交
  • --stat:显示简略统计信息,包括修改的文件和行数
  • --abbrev-commit:使用短提交哈希值
  • --pretty=<格式>:使用自定义的提交信息显示格式

git blame 文件名 以列表形式显示修改记录

3.3版本穿梭

  • git reset 版本号暂存区的目录树会被重写,被定义版本号指向的目录树所替换,但工作区不受影响
  • git rm --cached 文件名会直接从暂存区删除文件,工作区不作出改变
  • git checkout . 或者 git checkout -- 文件名会用暂存区全部或指定的文件替换工作区的文件。这个操作很危险,会清除工作区中未添加到暂存区中的改动
  • git checkout 分支名 .或者git checkout -- 文件名会用定义或指向分支中的全部或者部分文件替换暂存区和以及工作区中的文件。这个命令也是极具危险性的,因为不但会清除工作区中未提交的改动,也会清除暂存区中未提交的改动。

4Git分支操作

4.1分支概述及优点

  • 在版本控制过程中,同时推进多个任务,为每个任务可以创建单独分支,意味着可以将工作从开发主线上分离开来,开发分支不影响主线运行,可理解为副本
  • 并行推进多个功能开发,提高效率
  • 各个分支在开发过程中,单个分支开发失败,不会影响其他分支,失败分支可重新开始

4.2分支操作

git branch 分支名 #创建分支
git branch -v #查看分支
git checkout 分支名 #切换分支
git checkout -b 分支名 #创建新分支并切换
git switch 分支名 #切换分支
git switch -c 新分支名 #创建新分支并切换
git merge 分支名 #把指定的分支合并到当前分支上
git branch -d 分支名 #删除分支
4.2.1查看分支

git branch -v

4.2.2创建分支

git branch 分支名

4.2.3切换分支

git checkout 分支名

4.2.4合并分支

git checkout 主分支

git merge 分支名

  • 分支冲突:当要合并的两个分支存在对同一文件进行修改,git无法确定作哪一修改
  • 解决冲突:修改master中相同文件的内容,不修改合并分支中相同文件的内容
    • 在master分支确定要修改的文件及内容,git add 文件名
    • git commit -m “日志” (后不能加文件名,否则会报错)
    • 合并分支的同文件不做改变,git merge 合并分支名
4.2.5删除分支

git branch -d 分支名

5远程仓库

在这里插入图片描述
上图来自RUNOOB Git教程

5.1在github/gittee上创建远程仓库

5.2远程仓库操作

git remote -v #查看当前所有远程地址别名
git remote add 别名 远程地址 #起别名(第一次)
git push 别名 分支 #推送本地分支上的内容到远程仓库
git clone 远程地址 #将远程仓库的内容科隆到本地(第一次)
git pull 远程库地址别名 远程分支名 #将远程仓库对于分支最新内容拉下来后与当前本地分支直接将合并
5.2.1克隆仓库到本地

git clone 远程地址,执行该命令会默认处于master分支下,也会自动将origin设置成该远程仓库的标识符

git clone 远程地址 新名字克隆仓库并在本地修改仓库名

设置提交代码时的用户信息

git config --global user.name "abc"
git config --global user.email abc@qq.com
#如果去掉 --global 参数只对当前仓库有效。
5.2.2未工作区增加远程仓库
git remote -v #先查看当前所有远程地址一般会叫origin
git remote add 仓库别名 远程地址 #增加远程仓库
git remote -v #再次查看当前所有远程地址
#会有两个仓库,又分别有1个可以推送(push) 一个可以拉取(fetch)

#删除仓库
git remote rm 仓库名
5.2.3推送本地分支到远程仓库

git push 远程仓库地址别名 分支名,推送的最小单位是分支,所以一定要指定分支,例如:git push origin master

5.2.4拉取远程仓库内容

git pull 远程仓库地址别名 分支名,例如:git pull origin master

6版本控制(查看与更新远程分支)

git fetch 获取远程仓库中最新的提交和分支信息,但不会自动合并到当前分支上

例如:git fetch origin 从名为origin的远程仓库获取所有分支的最新更改

git diff 比较本地分支和远程分支之间的差异,避免潜在冲突,例如git diff HEAD origin/分支名,HEAD 是指当前分支的最新提交

然后进行合并:git merge orgin/分支名

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

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

相关文章

mirth Connect 自定义JAVA_HOME

mirth Connect 自定义JAVA_HOME 1、背景 服务器上安装了两个不同版本的Java&#xff0c;我希望Mirth服务使用与默认系统不同的版本。自定义指定java版本 2、解决方法 2.1 优先级说明 系统变量JAVA_HOME (设置后&#xff0c;mirth会根据这个进行启动运行服务&#xff0c;优先级…

2020 6.s081——Lab2:system calls

左岸的一座白色环形阶梯 浪人正在用和弦练习忧郁 晨曦下的少女听着吉他旋律 在许愿池边巴洛克式的叹息 ——许愿池的希腊少女 完整代码见&#xff1a;SnowLegend-star/6.s081 at syscall (github.com) System call tracing (moderate) 这个实验要求我们跟踪系统调用。 感觉实…

软件设计师,下午题 ——试题六

模型图 简单工厂模式 工厂方法模式抽象工厂模式生成器模式原型模式适配器模式桥接模式组合模式装饰&#xff08;器&#xff09;模式亨元模式命令模式观察者模式状态模式策略模式访问者模式中介者模式 简单工厂模式 工厂方法模式 抽象工厂模式 生成器模式 原型模式 适配器模式 桥…

nodemcu32s 和 mini D1 组局域网并用 webSocket 通信

实现思路 使用 mini D1 来搭建一个 webSocket 服务&#xff0c;然后使用 nodemcu32 连接&#xff0c;然后就可以进行通信了。 服务端代码&#xff08;mini D1&#xff09; 在代码中主要是需要控制好 loop 函数中的延时&#xff0c;也就是最后一行代码 delay&#xff0c;如果…

大模型时代的具身智能系列专题(六)

UCSD 王小龙组 王小龙是UCSD电子与计算机工程系的助理教授。他曾在加州大学伯克利分校与Alexei Efros和Trevor Darrell一起担任博士后研究员&#xff0c;在CMU RI获得了机器人学博士学位&#xff0c;师从Abhinav Gupta。他的研究重点是通过视频和物理机器人交互数据来学习3D和…

【AIGC】大型语言模型在人工智能规划领域模型生成中的探索

大型语言模型在人工智能规划领域模型生成中的新应用 一、引言二、LLM在规划领域模型生成中的潜力三、实证分析&#xff1a;LLM在规划领域模型生成中的表现四、代码实例&#xff1a;LLM在规划领域模型生成中的应用五、结论与展望 一、引言 随着人工智能技术的迅猛发展&#xff0…

yolov5-ros模型结合zed2相机部署在 Ubuntu系统

前言 本篇文章主要讲解yolov5-ros模型结合zed2相机进行实时检测&#xff0c;经改进实现了红绿灯检测&#xff0c;并输出检测类别与置信度&#xff01; 目录 一、环境配置二、zed2驱动安装三、yolov5-ros功能包配置四、运行官方权重文件四、运行自己权重文件 一、环境配置 1、…

分享6个打开就能让人眼前一亮的网站,每次浏览都像发现新大陆~

1、ZLibrary zh.zlibrary-be.se/ ZLibrary是一个广受欢迎的在线图书馆&#xff0c;它提供了一个庞大的电子书和文章资源库&#xff0c;数量超过千万。这个平台覆盖了国内外众多领域的电子书资源&#xff0c;几乎可以满足用户98%以上的搜索需求&#xff0c;无论是学术研究、文…

Netty中半包粘包的产生与处理:短连接、固定长度、固定分隔符、预设长度;redis、http协议举例;网络数据的发送和接收过程

目录 粘包、半包 相关概念 网络数据发送和接收过程 Netty半包粘包解决方案 ByteBuf获取和默认大小 短链接 固定长度 固定分隔符 预设长度 常见协议代码举例 redis协议 http协议 参考链接 粘包、半包 相关概念 程序处理过程中我们会通过缓冲区接收数据&#xff0c…

input输入框的一些复习

<template><div><div style"text-align: center;margin: 10px 0;"><span style"font-size: 15px;font-weight: bold;">input输入框的基本应用</span></div><el-descriptions :column"3" size"defau…

Golang dlv远程debug

1. 前期准备 1.1. dlv安装 1.1.1. go install安装 go install github.com/go-delve/delve/cmd/dlvlatest1.1.2. 手动安装 下载 linuxx86 架构 二进制文件 &#x1f4ce;dlv.linux.x86.zip zip文件&#xff0c;下载后&#xff08; 如果没权限&#xff0c;记得 执行chmod ax…

linux下使用cmake-gui编译WXQT

一.编译环境 操作系统&#xff1a;Ubuntu 22.04.3 LTS wxWidgets源码&#xff1a;wxWidgets-3.1.5 编译工具&#xff1a;CMake-gui qt版本&#xff1a;5.13.2 二.编译步骤 1.将源码解压。 2.打开CMake-gui&#xff0c;并设置好源码目录和构建目录 3.点击configure 会弹出…

【c++入门】this指针

this指针引出&#xff1a; 我们知道一个类可以有多个实例化对象&#xff0c;但是这多个实例化对象所调用的成员函数是在公共代码区&#xff1b; 我们先来定义一个Date类&#xff1a; class Date { public:void init(int year, int month, int day){_year year;_month month;…

excel怎么对非数字求和汇总?

如&#xff1a;学生小王的成绩为&#xff1a;A&#xff0c;A&#xff0c;A&#xff0c;A&#xff0c;B&#xff0c;B-……想得到的成绩汇总求和为&#xff1a;2A,2A,1B,1B- 如果在低版本里&#xff0c;用公式计算可能相当复杂&#xff0c;但是有了TEXTJOIN函数和UNIQUE函数&…

一、实现一个简单的 Google Chrome 扩展程序

目录 &#x1f9ed; 效果展示 # 图示效果 a. 拓展程序列表图示效果&#xff1a; b. 当前选项卡页面右键效果&#xff1a; c. 拓展程序消息提示效果&#xff1a; &#x1f4c7; 项目目录结构 # 说明 # 结构 # 文件一览 ✍ 核心代码 # manifest.json # background.j…

数据结构算法 数组的实现与练习(C语言实现,Java实现)

文章目录 数据结构数组(顺序表)特点使用Java实现更高级的数组C语言实现总结优点缺点 例题[26. 删除有序数组中的重复项](https://leetcode.cn/problems/remove-duplicates-from-sorted-array/)[1. 两数之和](https://leetcode.cn/problems/two-sum/)[27. 移除元素](https://lee…

阿里云部署nodejs

目录 1、安装node.js 1-1 进入opt/software 1-2 下载node.js安装包 1-3 解压 2 配置环境变量 2-1 vim中配置环境变量 2-2 命令行中保存环境变量 2-3 检查安装版本 2-3 更换镜像 3、上传node.js项目 1-1 启动项目 1-2 配置对应的安全组 ​编辑 4、pm2启动多个node项…

Scroll 上的明星项目Pencils Protocol ,缘何被严重低估?

近日&#xff0c;完成品牌升级的 Pencils Prtocol 结束了 Season 2 并无缝开启了 Season 3&#xff0c;在 Season 3 中&#xff0c;用户可以通过质押系列资产包括 $ETH、$USDT、$USDC、$STONE 、$wrsETH、$pufETH 等来获得可观收益&#xff0c;并获得包括 Scroll Marks、 Penci…

二叉树的前序遍历(oj题)

一、题目链接&#xff1a; https://leetcode-cn.com/problems/binary-tree-preorder-traversal/ 二、题目思路 先调用二叉树节点计算函数&#xff0c;得到二叉树的总结点数。然后申请该大小的数组空间。 再使用前序遍历&#xff0c;依次访问每个结点的数据&#xff0c;依次存…

01-1.2.3 算法的空间复杂度

什么是空间复杂度&#xff1f; 代码在运行之前需要先装入内存&#xff0c;程序代码需要占一定的位置&#xff08;在这边假设是100B&#xff09; 定义的变量和参数i&#xff0c;n都需要占用内存空间 //算法一——逐步递增型 void loveYou(int n) { //n为问题规模int i 1; /…