git 修改commit_Git从8到13 深入了解Git特性

666cd9540d88afe48c2dcf5f6fbf686e.png

上一章简单的介绍了一些常用的Git命令,这一章主要是深入了解一下Git的稍微高级的一些知识和指令。

8.首先我们先来通过查看Git目录里面的文件来深入了解一下Git版本控制的构造。

753cc55a3a2f023013afd5dacb41a8d1.png

查看HEAD可以知道当前所在的分支。

4dcd9ae582cbd3b40aa6111b8d1d98a9.png

在config文件里面存储着Git里面的一些配置信息,不同的Git分支里面内容不同。

5caf990aaa0b2e3a23937ea3e570e87e.png

在refs文件夹里面包含heads和tags。hears里面有不同的分支的名字;tags里面主要就是一些里程碑的内容,也就是通常所说的打的一个tag。

bc708c5406173527a09e4864048a2f20.png

594aee2256ac38ee5495ad94c1501c79.png

329ae4d3f04864930383e27885a0a6a8.png

9. objects文件夹里面存放的是Git里面核心的文件内容,主要是Git版本控制管理的三个对象,主要关系就是commit包含tree,tree里面包含blob。tree的话就是一个文件夹,blob就是文件的内容。 前面文件夹的名称加上文件里面的名称,通过命令行可以查看文件的类型和文件内容。 git cat-file -t md5值 查看类型 git cat-file -p md5值 查看内容 git branch -av 查看分支git status 查看文件的状态

423f5f5949edc2c047c3c78e46b57822.png

fef7839e3692365daf5bd4ba45f57220.png

90807e876e36ae63b9443b4a2f4d400a.png

6ef203a22680d2a94e887d3e760d9d93.png

10. 暂存区,工作区,head所含文件之间差异比较 git diff --cached #暂存区和head所含文件的差异比较git diff #工作区和暂存区比较差异 全部文件git diff -- readme.txt #工作区和暂存区比较差异 个别文件git diff HEAD HEAD~2 #比较不同的headgit diff temp master #比较俩个分支的差异 git diff temp master -- index.html #比较俩个分支同一文件的差异

261fe28a63c940f5024fd018f01f25c3.png

3ea4caa7096c302757a09849cefacd4b.png

ede45bfd4424ff517102aaac4f8e40d8.png

bf84edd8077a4748e15a57f072e73a70.png

11.分离头指针 当我们直接Check出来某个commit的时候,这个HEAD头指针不属于现在全部的branch版本的话,就是分离头指针。当我们在代码中做尝试性变更的时候会遇到这个场景,比如说只是想尝试性的写一些功能,但是又不想保存到控制版本里面的时候。所以我们在使用分离头指针的时候需要注意的是:commit提交一定要跟branch绑定在一起才会生效。git checkout c6693 #分离头指针git branch write 2f87f57 #保存分离头指针

bc17ef4cf5d52c491b09348b19031160.png

3cefedad9aecf1311e4d2b1c67d94aa5.png

0955207bcb7ecb167629c27bcfad8da1.png

在暂存区有时候写完的代码不想要了,需要全部恢复到工作区的时候。

git reset HEAD #把暂存区的全部内容恢复到工作区git reset HEAD 文件名 #把暂存区的部分内容恢复到工作区git reset --hard M5值 #恢复到指定的commit,取消最近的提交 这个操作有点危险哟。

26e1db6bb5ad5c16d926dd674d369e8a.png

2dd23ba83f4b772fbb118a3530972968.png

12. commit的一些高级指令
- 修改commit的内容
`git commit --amend #修改最新的commit` `git rebase -i c6693435 #修改以前的commit的到时候需要找到他的父亲然后修改` ![修改最新的commit](https://img-blog.csdnimg.cn/20190921191027777.png) ![变更老的commit成功](https://img-blog.csdnimg.cn/20190921191247836.png) ![修改以前的commit,这里需要将3efc626前面的pick改成r](https://img-blog.csdnimg.cn/20190921191436696.png) - 把多个连续的commit合成一个commit `git rebase -i c669343 `

df010d1dca2811007a328061b6ab39a7.png

e313a4724117433a44dd61b56441a8e0.png

8566c8fc20529432691bf6567698fe3d.png


- 把不连续的commit合成一个commit `git rebase -i c669343 `

13.将Git仓库备份到本地
说了这么多,没有远程仓储怎么行,下面就先让我们在本地初始化一个本地的Git仓库。 Git常用的传输协议有哑协议 /path/to/repo.git 智能协议 file:///path/to/repo.githttp/https协议 http://git-server.com:port/path/to/repo.git https://git-server.com:port/path/to/repo.git ssh协议 user@git-server.com:path/to/repo.git 最常用哑协议传输进度是不可见的;智能协议传输可见 并且智能协议比哑协议传输速度快。git clone --bare 地址 名称xx.gitgit clone --bare /e/BLOG/git/learn_git/.git ya.gitgit clone --bare file:///e/BLOG/git/learn_git/.git zhineng.gitgit remote add zhineng file///e/BLOG/tank/zhineng.git #同步到远端 git push zhineng

7e935e6215e5ea8ee191211edd984164.png

057da021a3df794c208a04ced235b1b2.png

bc948b3c49ad2f08cd2532f296e05de8.png

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

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

相关文章

mysql商品表_MySQL数据库创建商品表

(注:若直接复制上去会报错,可能是标点符号问题,所有标点符号均为英文状态!)1.商品分类表创建商品分类表(选择mydb数据库)use mydb;create table sh_good_category(id int unsigned primary key auto_increment comment ‘分类id’…

win执行mysql建库脚本_linux执行mysql脚本文件连接本地windows数据库

又开始玩linux了,小白一个,连ls命令都是这两天新学的,今天又学了点东西,贴上来备忘:需求:我是想要在linux执行一个.py文件,这个文件执行后可以远程连接我的本地windows的mysql数据库&#xff0c…

eclipse maven打包jar 部分jsp无法访问_Maven系列教材 (九)- 在Eclipse中创建maven风格的java web项目...

Maven系列教材 (九)- 在Eclipse中创建maven风格的java web项目步骤1:删除j2ee目录步骤2:新建Maven 项目步骤3:这个界面点下一步步骤4: 这个界面使用webapp,点下一步 步骤5:这一步填写如图所示的信息步骤6:此时得到的maven web 项目的问题步骤…

php mysql预处理_PHP MySQL 预处理语句

预处理语句对于防止 MySQL 注入是非常有用的。SQL注入,就是通过把SQL命令插入到Web表单递交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行恶意的SQL命令。预处理语句及绑定参数预处理语句用于执行多个相同的 SQL 语句,并且执行效…

final关键字_深入分析Java中的final关键字

Java中被final修饰的变量与普通变量有何区别?被final修饰的变量不可更改、被final修饰的方法不可重写是怎样做到的?带着疑问我们一点点拨开云雾。一、final的内存定义及规则对于final关键字,编译器、处理器从读写两个角度限制了其使用规则&am…

嵌入式和fpga哪个好前景_Java 和 go 哪个就业前景好一点?面向金钱编程,这个回答太现实...

有个朋友问我:ava 和 go 哪个就业前景好一点?现在纠结中,差不多一年半就要毕业了。我也问了几个朋友程序员朋友:朋友A: 可以参考 Boss 直聘,面向金钱编程,我身边的 Java 都是 15k 左右,反正干就…

php解决mysql主从同步_Mysql读写分离,主从同步实现

随着用户量的增多,数据库操作往往会成为一个系统的瓶颈所在,因此我们可以通过实现数据库的读写分离来提高系统的性能。通过设置主从数据库实现读写分离,主库负责“写”操作,从库负责“读”操作,根据压力情况&#xff0…

python创建数组的方法_numpy创建array的方法汇总

创建numpy.array,是使用numpy这个核武器的基础,本文尽量汇总常用创建numpy.array的方法。array函数>>> import numpy as np>>> a np.array([1,2,3,4,5])>>> aarray([1, 2, 3, 4, 5])>>> a.shape(5,)>>> a…

mysql_install_db is deprecated_MySQL5.7源码安装问题汇总

编译安装mysql5.7版本,想试用一下新的版本特性,发现跟之前的5.6版本编译有了一些变化,总结一下避免以后继续入坑。5.6安装方式cmake版本5.7编译cmake要求版本最低为2.8,当前为2.6,所以需要升级cmake版本。信息如下shel…

验证码图片显示不出来怎么办_pr 的蒙版不显示了怎么办?

小白自学pr一路会遇到很多坑,我也是在一个个坑里爬过的。画好的蒙版不显示了,这只能算是一个小坑。解决方法很简单,只需要记住一条:在pr里想要调整或者显示什么东西,首先必须要选中它。举例说明:我给小猫的…

gb2312编码表_汉字编码输入系统模型(一)

通过前面介绍的通信系统模型来分析汉字编码输入系统,将汉字编码输入系统的特殊性整合到通信系统模型中,从而建立起一种基于信息论的汉字编码输入系统模型(参见图3.2),以便指导我们的汉字编码输入实践,设计和…

python dict hash_【python-dict】dict的使用及实现原理

以下内容是针对:python源码剖析中的第五章——python中Dict对象 的读书笔记(针对书中讲到的内容进行了自己的整理,并且针对部分内容根据自己的需求进行了扩展)一、Dict的用法Dict的对象在使用到了所谓的关联关系的时候,就是通过key-value的形…

python参考文献_[zotero/python]库中参考文献条目删除后,清除残留PDF的脚本

更新:使用 滏阳河边捉蚯蚓 https://zhuanlan.zhihu.com/p/41297136上获取系统PDF文件和zotero.sqlite文件的代码,在此感谢!在zotero的library中删除参考文献条目后,有时PDF不会同步删除,尤甚是安装了zotfile插件后&…

java中sql语句怎么把开始和结束时间作为参数写sql查询_JDBC数据库连接怎么操作?...

之前一直听说过JDBC,但从来不知道它是何物的小伙伴们看过来啦!一、概述JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和接口组…

spring boot整合shiro继承redis_spring-boot-plus集成Shiro+JWT权限管理

SpringBootShiroJWT权限管理ShiroApache Shiro是一个强大且易用的Java安全框架,执行身份验证、授权、密码和会话管理。使用Shiro的易于理解的API,您可以快速、轻松地获得任何应用程序,从最小的移动应用程序到最大的网络和企业应用程序。三个核心组件:Subject, Secur…

java 整数变负数_一文帮你读懂Java整数的存储原理

前言大家应该都知道,整数包括负数,零,和正数。在Java中,基本类型中byte(8位)、short(16位)、int(32位)、long(64位)属于整数,并且没有无符号数,均是有符号的。对于计算机来说,它只认识二进制&am…

server2019 sqlcmd命令安装_Ubuntu20.04LTS安装MS sql-server2019的方法

在本文中,我将向您展示如何在Ubuntu 20.04 Focal Fossa上安装Microsoft SQL Server。小广告:喜欢网络技术的朋友可以加W信:xfiles_sky一起学习进步。步骤一:更新ubuntu源sudo apt update && sudo apt upgrade步骤二&#…

servlet里面为什么有时候覆_为什么新来的经理强烈推荐?前后端分离知识,学到了...

引言前后端分离这个词相信大家都听过,不知道大家是怎么理解的呢。前阵子看项目的时候,有一段实现硬是没看懂,下面来给大家说一下一段愚蠢的经历哈。(我没正正式式写过前端,所以如果文章有错的地方希望可以在评论区友善交流~)一、交…

lamp 安装 mysql_linux lamp之离线安装mysql

Linux下自己创建目录/tigger上传mysql压缩包到此目录[rootlocalhost tigger]# tar zxvf mysql.tar.gz[rootlocalhost tigger]# cp -r mysql /usr/local/mysql/usr/local/mysql 为安装目录cd /usr/local/mysql[rootlocalhost mysql]# groupadd mysql[rootlocalhost mysql]# user…

microstation添加txt文件_C开发实战-文件操作

文件概述文件几乎无处不在,主要分为磁盘文件和设备文件,典型的磁盘文件有文本文件和二进制文件,磁盘文件存储在外部存储介质(例如磁盘,硬盘,U盘等等)需要加载到内存中才能使用。无论是文本文件还是二进制文件在计算机内…