Git的学习,从入门到入土

Git常用命令

Git全局设置

安装完Git后,要先设置用户名称和email地址。因为每次Git提交都会使用该用户信息。

设置用户信息

git config --global user.name “……”

git config --global user.email “……”

查看配置信息

git config --list

获取Git仓库

要使用Git对代码进行版本控制,首先要获得Git仓库。

获取Git仓库通常有两种方式:

  1. 在本地初始化一个Git仓库(不常用)
  2. 从远程仓库克隆

在本地初始化仓库

在任意目录下创建一个空目录作为本地git仓库,进入这个目录中,点击右键打开Git bash窗口,再指定命令 git init

然后再目录中会出现一个.git文件夹(此文件夹为隐藏文件夹),说明Git仓库创建成功

从远程仓库克隆

可以通过Git提供的命令从远程仓库进行克隆,将远程仓库克隆到本地

一些概念

  • 版本库:以上提到的.git隐藏文件夹就是版本库,版本库中存储了很多配置信息、日志信息、文件版本信息等
  • 工作区:包含.git文件夹的目录就是工作区,也称为工作目录,主要用于存放开发的代码
  • 暂存区:.git文件夹中有很多文件,其中有一个index文件就是暂存区,也可以叫做stage。暂存区是一个临时保存修改文件的地方

工作区通过指令 git add 将对工作区的开发代码的修改放到暂存区,暂存区通过指令 git commit 将其修改提交到版本库

Git工作区中的文件存在两种状态:

  • untracked 未跟踪(未被纳入版本控制)
  • tracted 已跟踪(被纳入版本控制)
    • Unmodified 未修改状态
    • Modified 已修改状态
    • Staged 已暂存状态

Git本地仓库常用命令

本地仓库操作

本地仓库常用命令如下:

  • git status 查看文件状态
  • git add 将文件的修改加入暂存区
  • git reset 将暂存区的文件取消暂存或者是切换到指定版本
  • git commit 将暂存区的文件修改提交到版本库
  • git log 查看日志

关于git reset:

reset参数是重置命令

  • --hard是重置代码仓库版本

有三种模式

  • -soft 、--mixed以及--hard是三个恢复等级。

使用--soft就仅仅将头指针恢复,已经add的暂存区以及工作空间的所有东西都不变。 如果使用--mixed,就将头恢复掉,已经add的暂存区也会丢失掉,工作空间的代码什么的是不变的。 如果使用--hard,那么一切就全都恢复了,头变,aad的暂存区消失,代码什么的也恢复到以前状态。

以--hard为例: git reset --hard [版本id] 命令就是恢复到指定版本id对应的版本

在git log查看日志后,日志中的commit后面的一串字符串就是版本id

关于git commit:

git commit -m "注释信息” [提交的文件名]

-m意思是给本次提交加上注释信息,建议使用-m进行提交,否则会弹出一个注释编辑器(较难使用),直接使用-m进行注释即可

远程仓库操作

远程仓库常用命令如下:

  • git remote 查看远程仓库
  • git remote add 添加远程仓库
  • git clone 从远程仓库克隆
  • git pull 从远程仓库拉取
  • git push 推送到远程仓库

从远程仓库拉取

git pull命令的作用是从远程仓库获取最新版本合并到本地仓库,命令格式:

git pull [short-name] [branch-name]

short-name是指远程仓库名,branch-name是指分支名

如果当前本地仓库不是从远程仓库克隆,而是本地创建的仓库,并且仓库中存在文件,此时再从远程仓库拉取文件的时候会报错,如果要强行拉取,可以再git pull命令最后加上

--allow-unrelated-histories

推送到远程仓库

git push命令的作用是将本地仓库的新版本推送到远程仓库,命令格式:

git push [short-name] [branch-name]

short-name是指远程仓库名,branch-name是指分支名

分支操作

分支是Git使用过程中非常重要的概念。使用分支意味着可以把工作从开发主线上分离开来,避免影响开发主线。同一个仓库可以有多个分支,各个分支相互独立,互不干扰。通过git init命令创建本地仓库的时候会默认创建一个master分支。

关于分支的相关命令:

  • git branch 查看分支
  • git branch [name] 创建分支
  • git checkout [name] 切换分支
  • git push [shortName] [name] 推送到远程仓库分支
  • git merge [name] 合并分支

查看分支时,看到的分支前有一个*符号,并且该分支是绿色的,说明此分支是现在所在的分支

标签操作

Git中的标签,指的是某个分支某个特定时间点的状态。通过标签,可以很方便的切换到标记时的状态。比较有代表性的是可以使用这个功能类发布结点。

和标签相关的命令:

  • git tag 列出已有的标签
  • git tag [name] 创建标签
  • git push [shortName] [name] 将标签推送到远程仓库
  • git checkout -b [branch] [name] 检出标签

检出标签就是将指定标签的代码下载下来,下载的内容放到一个新的分支里面,[branch]就是用来指定这个新分支的名称

但是通常不会使用输入命令的方式来进行git操作,通常在idea中使用git,git中会有相应的按钮直接执行命令,既方便又简单,但是不好用文字描述,见相关视频即可

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

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

相关文章

特征工程(I)--探索性数据分析

有这么一句话在业界广泛流传:数据和特征决定了机器学习的上限,而模型和算法只是逼近这个上限而已。由此可见,特征工程在机器学习中占有相当重要的地位。在实际应用当中,可以说特征工程是机器学习成功的关键。 特征工程是数据分析…

33. UE5 RPG使用增强输入激活GameplayAbility(三)

在前面的文章,我们实现了使用GameplayTag和InputAction的对应绑定的数据,并且添加到了增强输入映射的上下文中,实现了通过按键打印对应的GameplayTag,这只是我们基础需要制作的。目的主要是为了实现在GameplayAblity上面设置对应的…

Linux slocate命令教程:安全快速的文件搜索工具(附实例详解和注意事项)

Linux slocate命令介绍 slocate(secure locate)是一个用于在系统中查找文件的命令。这是Linux命令locate的安全版本,它也用于文件搜索,类似于locate命令,它创建了一个文件位置的数据库以便更快地搜索。但是它比locate…

计算机网络 实验指导 实验16

实验16 PPP配置实验 1.实验拓扑图 实验10讲了如何添加Se的接口 名称接口IP地址Router1se0/0/0192.168.1.1/24Router0se0/0/0192.168.1.2/24se0/0/1192.168.2.1/24Router2se0/3/0192.168.2.2/24 2.实验目的 (1)掌握PPP的基本配置步骤和方法 &#xf…

linux之文件系统、inode和动静态库制作和发布

一、背景 1.没有被打开的文件都在磁盘上 --- 磁盘级文件 2.对磁盘级别的文件,我们的侧重点 单个文件角度 -- 这个文件在哪里,有多大,其他属性是什么? 站在系统角度 -- 一共有多少文件?各自属性在哪里&#xff1f…

Hive 之 UDF 运用(包会的)

文章目录 UDF 是什么?reflect静态方法调用实例方法调用 自定义 UDF(GenericUDF)1.创建项目2.创建类继承 UDF3.数据类型判断4.编写业务逻辑5.定义函数描述信息6.打包与上传7.注册 UDF 函数并测试返回复杂的数据类型 UDF 是什么? H…

数组-二维数组

本笔记为47 数组-二维数组定义方式_哔哩哔哩_bilibili的学习笔记 二维数组 定义方式 注: 常用第二种方式定义,原因:第二种方式更清晰列数可以省行数不可省 ,详见上述第四种定义方式 示例: 二维数组 数组名 作用&am…

【QT+QGIS跨平台编译】063:【qca-logger+Qt跨平台编译】(一套代码、一套框架,跨平台编译)

点击查看专栏目录 文章目录 一、qca-logger插件介绍二、QCA下载三、文件分析四、pro文件五、编译实践5.1 windows下编译5.2 linux下编译5.3 macos下编译一、qca-logger插件介绍 QCA::Logger 是 Qt Cryptographic Architecture (QCA) 库中的一个类,它提供了一个简单而灵活的日志…

PostgrerSQL基本使用与数据备份

前言 上篇了解了 PostgrerSQL 数据库的部署PostgreSQL关系型数据库介绍与部署-CSDN博客,本篇将继续就其基本操作、备份与还原内容做相关介绍。 目录 一、数据库的操作 1. 本机登录 2. 开启远程登录 2.1 开放远程端口 2.2 编辑配置文件 2.3 修改配置密码 2.…

xss.pwnfunction-Ma Spaghet!

根据代码得知 这个是根据get传参的并且是由someboby来接收参数的 所以 <script>alert(1137)</script> js并没有执行因为 HTML5中指定不执行由innerHTML插入的<script>标签 所以 ?somebody<img%20src1%20onerror"alert(1337)"> 这样就成…

PowerJob 分布式任务调度简介

目录 适用场景 设计目标 PowerJob 功能全景 任务调度 工作流 分布式计算 动态容器 什么是动态容器? 使用场景 可维护性和灵活性的完美结合 实时日志&在线运维 PowerJob 系统组件 PowerJob 应用场景 PowerJob 的优势 PowerJob&#xff08;原OhMyScheduler&…

Pytorch数据结构:GPU加速

文章目录 一、GPU加速1. 检查GPU可用性&#xff1a;2. GPU不可用需要具体查看问题3. 指定设备4.将张量和模型转移到GPU5.执行计算&#xff1a;6.将结果转移回CPU 二、转移原理1. 数据和模型的存储2. 数据传输3. 计算执行4. 设备管理5.小结 三、to方法的参数类型 一、GPU加速 .…

C#网页打印功能实现

在C# .NET Web中&#xff0c;可以通过使用JavaScript来实现点击按钮后以特定格式弹出打印窗口并进行打印。下面是一个简单的示例代码&#xff0c;演示了如何实现这个功能 <% Page Language"C#" AutoEventWireup"true" CodeBehind"Print.aspx.cs&q…

Lustre架构介绍的阅读笔记-基础知识

本文是在阅读Introduction to Lustre* Architecture的如下章节时的笔记。 Lustre – Fast, Scalable Storage for HPCLustre Scalable StorageLustre Building BlocksLustre Storage Scalability Lustre software services are implemented entirely within the Linux kernel,…

瑞_Redis_商户查询缓存_添加Redis缓存缓存更新策略

文章目录 项目介绍1 短信登录2 商户查询缓存2.1 什么是缓存2.1.1 缓存的应用场景2.1.2 为什么要使用缓存2.1.3 Web应用中缓存的作用2.1.4 Web应用中缓存的成本 2.2 添加Redis缓存2.2.1 背景2.2.2 缓存模型和思路2.2.3 代码实现2.2.4 测试附&#xff1a;IDEA控制台输出自动换行设…

【动态规划】【01背包】Leetcode 416. 分割等和子集

【动态规划】【01背包】Leetcode 416. 分割等和子集 ---------------&#x1f388;&#x1f388;416. 分割等和子集 题目链接&#x1f388;&#x1f388;------------------- 给你一个 只包含正整数 的 非空 数组 nums 。请你判断是否可以将这个数组分割成两个子集&#xff0…

前端部署报错

1.node-sass node 版本和 node-sass 版本不兼容 https://www.npmjs.com/package/node-sass POSTCSS RECEIVED UNDEFINED INSTEAD OF CSS STRING odeJSSupported node-sass versionNode ModuleNode 209.0115Node 198.0111Node 188.0108Node 177.0, <8.0102Node 166.093Node…

txt和jpg或png数据的自动化导入和自动化生成输出随用随拿

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、txt文件的自动化处理&#xff08;代码在上面链接&#xff09;二、txt文件自动化输出图片三、图片的自动化处理总结 前言 自动化导入和生成输出txt和jpg/pn…

泛型数组的赋值

ArrayList<String>[] arrayList new ArrayList[3];//不报错 ArrayList<String>[] arrayList new ArrayList<String>[3];//报错 泛型:编译期间检查&#xff0c;运行期间类型擦除 数组&#xff1a;运行期间检查 第一种情况允许的原因: 因为创建了一个未指…

Docker常用命令和高级操作

一、docker常用命令 1、安装命令 sudo apt install docker.io2、镜像管理 # 查看本地所有镜像 docker images # 移除指定镜像 docker image rm <image_name>:<tag>/<image_id># 其他命令 # dockerhub(https://hub.docker.com/)实在是太慢了 # 创建容器使用…