Git简易教程

news2024/12/29 10:54:22

安装与配置

教程链接

代码上传到远程仓库

在这里插入图片描述
workspace:当前所在的工作目录
stagingarea:修改暂存区
loacl repository:本地仓库
remote respository :远程仓库
我们首先在workspace目录编写代码、修改文件,然后需要使用add方法先将修改的部分添加到暂存区,commit方法添加到本地仓库。最终使用push方法上传代码。

总流程:
git init //将当前目录初始化为git可管理目录,生成.git目录里面包含文件相关信息
git add .//将当前目录下的所有修改文件提交至暂存区
git commit -m "first commit"//将暂存区的内容添加至本地仓库,并注释“first commit”
git remote add origin https://github.com/liyinchigithub/Git-commands.git//绑定所需要的远程仓库
git push origin master//提交代码到master分支
git add:
git add Test//添加指定目录到暂存区,包括子目录:
git add README hello.js //添加2个文件到暂存区
git add .//添加当前目录下的所有文件到暂存区:
git commit:
git commit -m "提交内容备注"
git push:
git push origin master//将本地的 master 分支推送到 origin 主机的 master 分支。
git push --force origin master//本地版本与远程版本有差异,但又要强制推送可以使用 --force 参数:
git push <远程主机名> <本地分支名>:<远程分支名>
remote:
git remote add origin https://github.com/liyinchigithub/Git-commands.git//绑定相关远程库

分支

创建一个分支相当于新建一个工作节点,不会影响其它已有代码看,如图新建了一个new分支
在这里插入图片描述

branch:
git branch //查看当前所有分支
git branch new//创建一个新分支new
git checkout new//切换到 new
git branch -d new//删除new分支
git push origin --delete new//删除远程代码库的new分支

分支合并

假设两个人同时在一个项目上面编写代码,A进行base分支,B进行new分支,他们都进行了一下代码更改,项目进展如下
在这里插入图片描述

如果将new添加到base上即为图1,将base添加到new中如图2
在这里插入图片描述

合并原理为三项合并,假设当前是将new合并至base中
在这里插入图片描述
这个base 为他们最近公共祖先,Mine为当前base,Yours为now分支合并后代码为

Paint(”hello“);(蓝色节点)

这个样子就是发生冲突了,是无法合并的,需要修改
在这里插入图片描述

git checkout new//切换到new工作节点
git pull//拉取相关代码并进行编码
git checkout master//切换为主分支
git merge new//将new分支合并到master分支
git push -u origin master//推送至远程库

回滚

git log // 查询要回滚的 commit_id
 
git reset --hard commit_id // HEAD 就会指向此次的提交记录
 
git push origin HEAD --force // 强制推送到远端
git reset HEAD^ hello.js //回退hello.js的上个版本
git reset --hard origin/master//回退成线上版本

撤销提交

git log // 查找需要撤销的 commit_id
 
git revert commit_id  // 撤销这次提交

日志

git log --author//查看指定作者
git log --reverse //翻转
git log --oneline --before={3.weeks.ago} --after={2020-04-23} --no-merges//查看指定日期
git log --graph//查看分支合并情况
git reflog//查看commit日志

删除修改文件

git rm <file> // 从工作区和暂存区删除某个文件
 
git commit -m "" // 再次提交到仓库
git checkout -- <file>//暂存区覆盖工作区
git rm --cached <file>//工作区不做改变

从远程仓库拉取代码

git pull origin
git pull https://github.com/liyinchigithub/Git-commands.git

对比暂存区和工作区

git status

标签

版本可能会有多次提交,我们可以把某个提交打上标签,作为一个里程碑(version)

git add .
 
git commit -m "first commit"
 
git push origin master
 
git push origin v1.0
git push origin :refs/tags/v1.0//删除分支

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

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

相关文章

三十五、nacos注册中心集群搭建、网关、过滤器

1、nacos注册中心集群的搭建 要想搭建nacos集群模式&#xff0c;这些集群中的每台nacos服务&#xff0c;都必须连接同一个数据库。因为我们的nacos都放在同一台主机上&#xff0c;所以我们必须为每台nacos起不同的端口号。 1.1修改nacos端口号 8849 8850 8851 E:\software\naco…

2023/5/15总结

Java基础&#xff08;4&#xff09; 标准类制作 成员变量使用private修饰构造方法&#xff1a;提供一个无参构造方法&#xff0c;提供一个带多个参数的构造方法 成员方法&#xff1a;提供每一个成员变量对应的setXxx()/getXxx(),提供一个显示对象信息show()创建对象并为其成员…

服务端渲染

服务端渲染 和 前后端分离&#xff01; 渲染 什么是渲染呢 ? 其实很简单, 就是把数据反应在页面上&#xff0c;说白了, 就是利用 js 的语法, 把某些数据组装成 html 结构的样子, 放在页面上展示。 举个例子 : 1. 准备一段 html 结构 <h1>hello world</h1> <di…

Android之 Service服务详解

一 四大组件 1.1 Activity组件&#xff0c;它一个单独的窗口&#xff0c;程序流程都必须在Activity中运行&#xff0c;所有它是最基本的模块。 1.2 service组件&#xff0c;用于在后台完成用户指定的操作。 1.3 content provider组件&#xff0c;会为所有的应用准备一个内容…

零知识证明:重要构造

文章目录 ZKP for NPBlums ZK PoK for HCCompletenessSoundnessZero KnowledgeWI of n-parallelized versionsProof of KnowledgeSpecial Soundness Constant Round ZKPFLS ParadigmGK Paradigm 在 零知识证明&#xff1a;安全定义 中介绍了 ZKP 的一些安全性定义&#xff0c;…

TFT驱动ST7789使用总结

最近在使用一款TFT驱动芯片ST7789&#xff0c;在阅读芯片数据手册和液晶屏数据手册时&#xff0c;发现总是对不上&#xff0c;芯片手册中&#xff0c;有好几个引脚&#xff0c;一会儿是这个作用&#xff0c;一会儿又变成另一种作用&#xff0c;实在是让人感到混淆。网上找了好久…

第三十六天学习记录:C语言进阶:指针详解Ⅳ

指向函数指针数组的指针 指向函数指针数组的指针是一个指针&#xff0c;指针指向一个数组&#xff0c;数组的元素都是函数指针。 int(*pfArr[4])(int, int);//pfArr是一个数组-函数指针的数组int(*(*ppfArr)[4])(int, int) &pfArr;//ppfArr是一个数组指针&#xff0c;指针…

网络进阶学习:重要网络协议(tcp协议,udp协议,http协议)

重要网络协议&#xff08;tcp协议&#xff0c;udp协议&#xff0c;http协议&#xff09; 网络协议是什么?TCP协议UDP协议HTTP协议TCP与UDP的职能区别⭐TCP职能⭐就TCP原理层面说应该分为三部分建立连接数据传输断开连接 ⭐UDP职能⭐就UDP原理层面说应该分为三部分发送数据数据…

单链表(增、删、查、改)的详细介绍 必看!!!

文章目录 链表介绍单链表初始化单链表打印增加节点单链表的头插单链表的尾插在给定位置之后插入在给定位置之前插入 删除节点单链表的头删单链表的尾删删除给定位置之后的节点删除给定位置处的节点 查找节点修改节点单链表销毁 链表介绍 链表是一种物理存储单元上非连续、非顺序…

【Mybatis】如何实现ORM映射-二

唠嗑部分 上篇文章我们说了Mybatis基本的CRUD操作及工具类的封装&#xff0c;相关文章&#xff1a; 【Mybatis】简单入门及工具类封装-一 大家都知道&#xff0c;Mybatis是半自动化的ORM框架&#xff0c;那么它到底是如何帮我们完成ORM映射的呢&#xff1f; 这就是本篇文章和…

SpringBoot整合Dubbo+Zookeeper

第一步、使用IDE创建一个SpringBoot项目 第二步、启动一个Zookeeper服务&#xff08;如果是第一次安装且没有配置zoo.cfg&#xff0c;此时会报出zookeeper服务器会提示缺少zoo.cfg文件&#xff09; 在zookeeper安装目录下的conf文件夹内有一个名为zoo_sample.cfg的配置文件&a…

[深度学习思想] ControlNet 工作原理

Stable Diffusion (2021 https://arxiv.org/abs/2112.10752) 带领了vision领域&#xff0c;具体是AI绘画领域达到了一个新高度。但是可控性成为使用的一个大瓶颈。Controlnet (2023 https://arxiv.org/abs/2302.05543) 提出一个深度学习模型框架&#xff0c;很好解决这个问题&a…

Liunx基础命令 - touch命令

touch命令 – 创建空文件与修改时间戳 touch命令的功能是用于创建空文件与修改时间戳。如果文件不存在&#xff0c;则会创建出一个空内容的文本文件&#xff1b;如果文件已经存在&#xff0c;则会对文件的Atime&#xff08;访问时间&#xff09;和Ctime&#xff08;修改时间&a…

带头双向循环链表(增、删 、查、改)基本操作详细介绍 必看!!!

文章目录 链表介绍链表初始化链表打印查找元素增加节点头插尾插在指定位置插入 删除节点头删尾删删除指定位置节点 链表判空获取链表中元素的个数链表销毁 链表介绍 前面说到&#xff0c;链表的结构一共有八种&#xff1a;带头单向循环链表、带头单向非循环链表、带头双向循环…

渗透测试--3.2捕获和监听网络数据

目录 1.监听捕获数据方法 2.kali监听捕获工具介绍 arpspoof driftnet 1.监听捕获数据方法 渗透测试中&#xff0c;捕获和监听网络数据是非常重要的一项任务&#xff0c;可以帮助我们发现潜在的漏洞和攻击面。以下是一些常见的捕获和监听网络数据的方法&#xff1a; 抓包工…

Liunx基础命令 - cp复制命令

cp命令 – 复制文件或目录 cp命令来自英文单词“copy”的缩写&#xff0c;中文译为“复制”&#xff0c;其功能是用于复制文件或目录。cp命令能够将一个或多个文件或目录复制到指定位置&#xff0c;亦常用于文件的备份工作。-r参数用于递归操作&#xff0c;复制目录时若忘记添…

网络编程——UDP编程

UDP编程 UDP编程步骤通信流程serverclient 函数接口socketbindrecvfromsendto 举例UDP客户端UDP服务器 UDP编程步骤 在C语言中进行UDP编程的一般步骤如下&#xff1a; &#xff08;1&#xff09;包含头文件&#xff1a; 在代码中包含必要的头文件&#xff0c;以便使用UDP编程所…

借助国内ChatGPT平替+剪映/百度AIGC平台快速制作短视频

系列文章目录 借助国内ChatGPT平替MindShow&#xff0c;飞速制作PPT 借助国内ChatGPT平替markmap/Xmind飞速生成思维导图 文章目录 系列文章目录前言一、科大讯飞“星火”认知大模型二、使用步骤1.借助讯飞星火生成短视频的文案2.选择剪映生成短视频3.选择百度AIGC平台生成短…

redis复制机制

文章目录 1. Redis 复制机制2. 基本命令3. 修改配置文件4. 代码案例4.1 一主二仆4.2 薪火相传4.3 反客为主 5. Redis复制工作流程6. Redis 复制的缺点 1. Redis 复制机制 概念 : Redis 复制机制 能干的活 : 读写分离 &#xff1a; 写 就找 主机 master &#xff0c; 读就找从机…

Centos7离线安装Docker

在我们部署Docker镜像时&#xff0c;难免会遇到服务器没有网络情况&#xff0c;这时候我们就需要离线安装Docker 参考文档&#xff1a;https://docs.docker.com/engine/install/binaries 下载Docker安装包 下载地址&#xff1a;https://download.docker.com/linux/static/st…