git常用命令
(一)克隆代码(clone):将远程仓库代码克隆到本地仓库
克隆远程仓库某个分支
git clone -b 远程分支名称 https://github.com/master/master.git 本地文件名称
克隆远程仓库默认分支
git clone https://github.com/master/master.git
(二)检出代码(checkout):将本地仓库代码检出到工作区
创建新的分支并切换到这个分支
git checkout -b 分支名称
切换到某个分支
git checkout 分支名称
分支重命名
git branch -m 老分支名称 新分支名称
查看本地分支
git branch
查看远程分支
git branch -r
删除本地分支(必须切换到其他分支,才能删除这个分支)
git branch --delete 分支名称
删除远程分支
git push origin --delete 分支名称
(三)添加代码(add):将工作区代码添加到暂存区
查看代码中修改了哪些文件、新增了哪些文件
git status
修改的文件:添加文件到暂存区
git add ./test.cpp
新增的文件:强制增加文件到暂存区
git add -f ./test.cpp
添加所有文件到暂存区
git add *
添加所有文件到暂存区
git add .
将已跟踪文件中的修改和删除的文件添加到暂存区,不包括新增加的文件
git add -u .
将所有的已跟踪的文件的修改与删除和新增的未跟踪的文件都添加到暂存区
git add -A .
添加某个文件类型到暂存区
git add *.cpp
添加整个文件夹到暂存区
git add src/
删除文件
git rm ./test.cpp
(四)提交代码(commit):将暂存区代码提交到本地仓库
查看本地分支和远程分支的区别
git diff
查看本地分支和特定分支的区别
git diff origin/master
查看本地分支和远程分支的某个文件的区别
git diff ./test.cpp
将暂存区的代码提交到本地仓库
git commit -m “描述信息”
如何撤回commit?
HEAD^ 撤回 上一个版本
HEAD~1 撤回 上一个版本
HEAD~2 撤回 上两个版本
commit_id 撤回到 某个指定版本
(1)撤回提交到本地仓库的commit
第一步 获取要撤回到的commit ID
git log
第二步 撤回到历史commit
撤回上一个版本
git reset --soft HEAD^
撤回上一个版本
git reset --soft HEAD~1
撤回上两个版本
git reset --soft HEAD~2
撤回到 某个commit
使用 --hard 参数会抛弃当前工作区,暂存区,本地版本区的修改
git reset --hard commit_id
使用 --soft 参数会抛弃当前本地版本区的修改,但保留当前工作区和暂存区的修改,可以重新提交
git reset --soft commit_id
使用 --mixed 参数会抛弃当前暂存区和本地版本区的修改,但保留当前工作区修改,可以重新提交
git reset --mixed commit_id
(2)撤回提交到远程仓库的commit
第一步 获取要撤回的commit ID
git log
撤回上一个版本
git reset --soft HEAD^
撤回上一个版本
git reset --soft HEAD~1
撤回上两个版本
git reset --soft HEAD~2
撤回到 某个commit
使用 --hard 参数会抛弃当前工作区,暂存区,本地版本区的修改
git reset --hard commit_id
使用 --soft 参数会抛弃当前本地版本区的修改,但保留当前工作区和暂存区的修改,可以重新提交
git reset --soft commit_id
使用 --mixed 参数会抛弃当前暂存区和本地版本区的修改,但保留当前工作区修改,可以重新提交
git reset --mixed commit_id
第三步 将本地撤回到的commmit提交到远程仓库
git push origin HEAD --force
(五)拉取代码(pull):将远程仓库代码拉取到本地仓库(合master)
将远程仓库的主干分支(master分支)合并到本地分支
git pull origin master
如果产生冲突,如何处理?
两种情况:
(1)提交的代码与master有冲突
确认提交的代码没有问题,删除master的代码,保留提交的代码
(2)提交的代码与其他人提交的代码有冲突,其他人优先于你合了master
将其他人已经合到master的改动添加到提交的代码中
(六)推送代码(push):将本地仓库代码推送到远程仓库
将本地分支推送到远程分支(如果远程分支不存在,就创建一个新的远程分支)
git push origin 本地分支名称:远程分支名称
将本地分支推送到与之存在追踪关系的远程分支(通常两者同名),如果该远程分支不存在,则新建这个远程分支。
git push origin 本地分支名称
如果本地分支和远程分支存在追踪关系,本地分支和远程分支都可以省略。将本地分支推送到origin主机上的对应分支。
git push origin
(七)master分支打tag
查看存在的tag
git tag
删除本地tag
git tag -d tag名称
删除远程tag
git push origin --delete tag tag名称
打tag
git tag -a tag名称 -m “描述信息”
推送tag
git push origin tag名称
相关文章:
git常用命令
(一)克隆代码(clone):将远程仓库代码克隆到本地仓库 克隆远程仓库某个分支 git clone -b 远程分支名称 https://github.com/master/master.git 本地文件名称 克隆远程仓库默认分支 git clone https://github.com/mas…...

2022年12月电子学会Python等级考试试卷(一级)答案解析
青少年软件编程(Python)等级考试试卷(一级) 一、单选题(共25题,共50分) 1. 关于Python语言的注释,以下选项中描述错误的是?( ) A. Python语言有两种注释方式&…...

大数据未来会如何发展
大数据应用的重要性,自全国提出“数据中国”的概念以来,我们周围默默地在发挥作用的大数据逐渐深入人们的心中,大数据的应用也越来越广泛,具体到金融、汽车、餐饮、电信、能源、体育和娱乐等领域 为什么大数据技术那么火…...

2022黑马Redis跟学笔记.基础篇(一)
2022黑马Redis跟学笔记.基础篇 一1.Redis入门1.1.认识NoSQL1.1.1.结构化与非结构化1.1.2.关联和非关联1.1.3.查询方式1.1.4.事务1.1.5.总结1.2.认识Redis1.3.安装Redis步骤一:安装Redis依赖步骤二:上传安装包并解压步骤三:启动(1).默认启动(2…...

【Spring(十一)】万字带你深入学习面向切面编程AOP
文章目录前言AOP简介AOP入门案例AOP工作流程AOP切入点表达式AOP通知类型AOP通知获取数据总结前言 今天我们来学习AOP,在最初我们学习Spring时说过Spring的两大特征,一个是IOC,一个是AOP,我们现在要学习的就是这个AOP。 AOP简介 AOP:面向切面编程,一种编程范式&#…...

基于Java+SpringBoot+Vue+uniapp前后端分离图书阅读系统设计与实现
博主介绍:✌全网粉丝3W,全栈开发工程师,从事多年软件开发,在大厂呆过。持有软件中级、六级等证书。可提供微服务项目搭建、毕业项目实战、项目定制✌ 博主作品:《微服务实战》专栏是本人的实战经验总结,《S…...

2021年新公开工业控制系统严重漏洞汇总
声明 本文是学习ITOT一体化工业信息安全态势报告(2019). 而整理的学习笔记,分享出来希望更多人受益,如果存在侵权请及时联系我们 工业互联网安全威胁 2021年新公开工业控制系统严重漏洞 缓冲区溢出漏洞 缓冲区溢出(buffer overflow&…...

Canvas鼠标滚轮缩放以及画布拖动(图文并茂版)
Canvas鼠标滚轮缩放以及画布拖动 本文会带大家认识Canvas中常用的坐标变换方法 translate 和 scale,并结合这两个方法,实现鼠标滚轮缩放以及画布拖动功能。 Canvas的坐标变换 Canvas 绘图的缩放以及画布拖动主要通过 CanvasRenderingContext2D 提供的 …...

[ECCV 2020] FGVC via progressive multi-granularity training of jigsaw patches
Contents IntroductionProgressive Multi-Granularity (PMG) training frameworkExperimentsReferencesIntroduction 不同于显式地寻找特征显著区域并抽取其特征,作者充分利用了 CNN 不同 stage 输出的特征图的语义粒度信息,并使用 Jigsaw Puzzle Generator 进行数据增强来帮…...

Python推导式
列表(list)推导式 [remove for source in xx_list]或者[remove for source in xx_list if condition] 实例: names[Bob,Mark,Mausk,Johndan,Wendy] new_names[name.upper() for name in names if len(name)<5] print(new_names)即迭代列…...
Java列表List的定查改增删操作
Java列表List的定查改增删操作定义查找遍历元素与下标互查修改增加删除java.util中提供了三种常用的集合类,列表List、集合Map和字典Set。这些集合类相较于数组有更多功能,并且都可以通过Iterator(迭代器)来访问。 在这篇博客中&…...
day03java语言特性 JDK、JRE、JVM
1、Java语言的特性 1.1、简单性在Java语言当中真正操作内存的是:JVM(Java虚拟机)所有的java程序都是运行在Java虚拟机当中的。而Java虚拟机执行过程中再去操作内存。对于C或者C来说程序员都是可以直接通过指针操作内存的。C或者C更灵活&…...

HydroD 实用教程(二)有限元模型
目 录一、前言二、模型种类三、单元类型四、FEM文件五、参考文献一、前言 SESAM (Super Element Structure Analysis Module)是由挪威船级社(DNV-GL)开发的一款有限元分析(FEA)系统,它以 GeniE、…...

Java中的Set集合
Set不能存储重复元素,元素无序(指的是不按照添加的顺序,List集合是按照添加顺序存储的)hashSet注:源码底层是hashMap实现的,因为hashMap是双列的,其中键是不能重复的,而hashSet是单列…...

【RabbitMQ五】——RabbitMQ路由模式(Routing)
RabbitMQ路由模式前言RabbitMQ模式的基本概念为什么要使用Rabbitmq 路由模式RabbitMQ路由模式组成元素路由模式完整代码Pom文件引入RabbtiMQ依赖RabbitMQ工具类生产者消费者1消费者2运行结果截图前言 通过本篇博客能够简单使用RabbitMQ的路由模式。 本篇博客主要是博主通过官网…...

【C语言】宏定义 结构体 枚举变量的用法
目录 一、数据类型 二、C语言宏定义 三、C语言typedef重命名 四、 #define与typedef的区别 五、结构体 六、枚举变量 补充学习一点STM32的必备基础知识 一、数据类型 二、C语言宏定义 关键字:#define 用途:用一个字符串代替一个数字,…...

锁升级之Synchronized
Synchronized JVM系统锁一个对象里如果有多个synchronized方法,同一时刻,只要有一个线程去调用其中的一个synchronized方法,其他线程只能等待!锁的是当前对象,对象被锁定后,其他线程都不能访问当前对象的其…...

基于nodejs+vue疫情网课管理系统
疫情网课也都将通过计算机进行整体智能化操作,对于疫情网课管理系统所牵扯的管理及数据保存都是非常多的,例如管理员:首页、个人中心、学生管理、教师管理、班级管理、课程分类管理、课程表管理、课程信息管理、作业信息管理、请假信息管理、上课签到管理、论坛交流…...

Zabbix 构建监控告警平台(三)
Zabbix User parametersZabbix Trigger1.Zabbix User parameters 1.1即自定义KEY 注意:mysql安装在被监测主机 [rootlocalhost ~]# yum -y install mariadb-server mariadb [rootlocalhost ~]# systemctl start mariadb [rootlocalhost ~]# mysqladmin -uroot statu…...
Linux系统之dool命令行工具的基本使用
Linux系统之dool命令行工具的基本使用一、dool命令行工具介绍二、本地系统环境检查1.检查系统版本2.检查系统内核版本三、下载dool软件包1.创建下载目录2.下载dool四、安装dool1.安装python32.安装dool五、dool的命令帮助六、dool的基本使用1.直接使用dool监控系统2.监控cpu和网…...
在软件开发中正确使用MySQL日期时间类型的深度解析
在日常软件开发场景中,时间信息的存储是底层且核心的需求。从金融交易的精确记账时间、用户操作的行为日志,到供应链系统的物流节点时间戳,时间数据的准确性直接决定业务逻辑的可靠性。MySQL作为主流关系型数据库,其日期时间类型的…...

树莓派超全系列教程文档--(61)树莓派摄像头高级使用方法
树莓派摄像头高级使用方法 配置通过调谐文件来调整相机行为 使用多个摄像头安装 libcam 和 rpicam-apps依赖关系开发包 文章来源: http://raspberry.dns8844.cn/documentation 原文网址 配置 大多数用例自动工作,无需更改相机配置。但是,一…...
在鸿蒙HarmonyOS 5中实现抖音风格的点赞功能
下面我将详细介绍如何使用HarmonyOS SDK在HarmonyOS 5中实现类似抖音的点赞功能,包括动画效果、数据同步和交互优化。 1. 基础点赞功能实现 1.1 创建数据模型 // VideoModel.ets export class VideoModel {id: string "";title: string ""…...

DIY|Mac 搭建 ESP-IDF 开发环境及编译小智 AI
前一阵子在百度 AI 开发者大会上,看到基于小智 AI DIY 玩具的演示,感觉有点意思,想着自己也来试试。 如果只是想烧录现成的固件,乐鑫官方除了提供了 Windows 版本的 Flash 下载工具 之外,还提供了基于网页版的 ESP LA…...

安宝特方案丨船舶智造的“AR+AI+作业标准化管理解决方案”(装配)
船舶制造装配管理现状:装配工作依赖人工经验,装配工人凭借长期实践积累的操作技巧完成零部件组装。企业通常制定了装配作业指导书,但在实际执行中,工人对指导书的理解和遵循程度参差不齐。 船舶装配过程中的挑战与需求 挑战 (1…...

排序算法总结(C++)
目录 一、稳定性二、排序算法选择、冒泡、插入排序归并排序随机快速排序堆排序基数排序计数排序 三、总结 一、稳定性 排序算法的稳定性是指:同样大小的样本 **(同样大小的数据)**在排序之后不会改变原始的相对次序。 稳定性对基础类型对象…...
现有的 Redis 分布式锁库(如 Redisson)提供了哪些便利?
现有的 Redis 分布式锁库(如 Redisson)相比于开发者自己基于 Redis 命令(如 SETNX, EXPIRE, DEL)手动实现分布式锁,提供了巨大的便利性和健壮性。主要体现在以下几个方面: 原子性保证 (Atomicity)ÿ…...

Golang——6、指针和结构体
指针和结构体 1、指针1.1、指针地址和指针类型1.2、指针取值1.3、new和make 2、结构体2.1、type关键字的使用2.2、结构体的定义和初始化2.3、结构体方法和接收者2.4、给任意类型添加方法2.5、结构体的匿名字段2.6、嵌套结构体2.7、嵌套匿名结构体2.8、结构体的继承 3、结构体与…...

门静脉高压——表现
一、门静脉高压表现 00:01 1. 门静脉构成 00:13 组成结构:由肠系膜上静脉和脾静脉汇合构成,是肝脏血液供应的主要来源。淤血后果:门静脉淤血会同时导致脾静脉和肠系膜上静脉淤血,引发后续系列症状。 2. 脾大和脾功能亢进 00:46 …...
Java并发编程实战 Day 11:并发设计模式
【Java并发编程实战 Day 11】并发设计模式 开篇 这是"Java并发编程实战"系列的第11天,今天我们聚焦于并发设计模式。并发设计模式是解决多线程环境下常见问题的经典解决方案,它们不仅提供了优雅的设计思路,还能显著提升系统的性能…...