5.Git基础-撤销操作、标签的使用、Git别名
1.撤销操作
1.1 修改上一次的提交(commit)-- git commit --amend
有时候我们在提交完成之后才发现有几个文件没有提交,或者发现提交信息填写错了,这时候可以使用 git commit --amend 尝试重新进行提交。
1.这条命令会将暂存区中的文件进行提交
2.在提交的时候可以修改上一次commit的提交信息
3.最终只有一次commit,第二次的commit会替代第一次的commit(也就是只会产生一个commit节点,使用 git log 会看到上一次的commit不见了,被这次的新commit替换)
1.2 取消暂存的文件 -- git reset HEAD <filename>
使用 git reset HEAD <filename> 可以将暂存的文件变为未暂存的文件。
1.3 撤销对文件的修改 -- git checkout -- <filename>
当你对一个文件进行了修改,还没有add进暂存区,你想要放弃所有的修改,将文件恢复到没有修改之前的样子,这时候可以使用 git checkout -- <filename>
这条命令会将文件恢复到上一次commit的时候,这个文件的样子。
2.打标签
打标签是指给一个commit打上标签,表示这个commit的重要性。通常人们会用这个功能来标记发布节点(例如v1.0等)。
2.1 列出标签 -- git tag
git tag 会按照字母顺序列出所有的标签。
git tag -l '<condition>' 列出感兴趣的标签。例如git tag -l 'v1.0*' 列出v1.0系列的标签。
2.2 创建标签
Git中的标签只有两种:轻量标签(lightweight)和附注标签(annotated)。通常建议使用附注标签,因为附注标签的信息更为全面,会包括打标签者的名字、电子邮件地址、日期时间等。
1.附注标签 -- git tag -a v1. -m "version 1.4"
使用-a就可以为某个提交打上附注标签了。-m指定标签的描述信息。
3.轻量标签 -- git tag v1.
轻量标签本质上是将提交校验和存储在一个文件中,没有保存其他任何信息。
2.3 查看特定标签的相关信息 -- git show v1.4
1.显示标签的相关信息;
2.显示标签被打在了哪个commit上。(对于轻量标签,只会显示标签被打在了哪个commit上)
2.4 对过去的提交打标签 -- git tag -a <tag name> -m <tag info> <commit 的hash值>
给指定的commit打上标签。这个指定的commit可以是很久以前提交的节点。也就是说给过去的commit打标签。
2.5 标签的共享 -- git push origin <tag name>
如果想将本地的tag上传到远程仓库,则必须显示的将tag push上去。默认情况下 git push 是不会将tag上传到远程仓库的。
一次推送许多标签: git push origin --tags 会将不在远程仓库的所有标签上传上去。
2.6 删除标签 -- git tag -d <tagname>
注意这条命令不会更新远程仓库。
使用 git push origin :refs/tags/<tagname> 来更新删除远程仓库的tag。
3.Git别名
Git不会再你输入命令的时候推断出你想要输入的命令,如果不想要每次都输入完整的命令,这时候可以给命令定义别名,每次输入的时候输入别名就可以了。
可以通过config文件来实现:例如 $ git config --global alias.co checkout 给checkout去别名为co,那么每次在输入的时候,就可以使用git co来代替git checkout了。
下面的2个别名可以加入到config中:
$ git config --global alias.unstage 'reset HEAD --' //使用git unstage表示取消暂存的操作,这样更加直观
$ git config --global alias.last 'log -1 HEAD' //使用git last表示显示最后一个commit的相关信息
上面只是对Git的内部命令取别名。如果你想要对Git的外部命令取别名,那么你在命令前面加上!。
$ git config --global alias.visual '!gitk' //将git visual定义为gitk
5.Git基础-撤销操作、标签的使用、Git别名的更多相关文章
- git基础-撤销操作
---恢复内容开始--- 撤销操作 在任何阶段,你都有可能想要撤销某些操作. 当我们提交完了代码,发现漏掉了几个文件没有添加,后者提交信息写错了,此时,可以运行--amend选项的提交命令尝试重新提交 ...
- 2.4 Git 基础 - 撤消操作
2.4 Git 基础 - 撤消操作 撤消操作 任何时候,你都有可能需要撤消刚才所做的某些操作.接下来,我们会介绍一些基本的撤消操作相关的命令.请注意,有些撤销操作是不可逆的,所以请务必谨慎小心,一旦失 ...
- Git的撤销操作
https://blog.csdn.net/qq_36431213/article/details/78858848 Git 初接触 (三) Git的撤销操作 git reset HEAD -- gi ...
- 4 Git 基础 - 撤消操作
撤消操作 任何时候,你都有可能需要撤消刚才所做的某些操作.接下来,我们会介绍一些基本的撤消操作相关的命令.请注意,有些撤销操作是不可逆的,所以请务必谨慎小心,一旦失误,就有可能丢失部分工作成果. 修改 ...
- git 基础入门操作
前言: 介绍基础的git入门级指令,虽然git指令非常多,但是实际工作中,我们会用到的非常少,小项目中甚至只需要用到2.3个.而且大部分人都会采用gui,而不是每次都打开终端然后输一长串难记的指令. ...
- Git III: 撤销操作
所谓撤销操作,无非就是后悔药.对Git来说,撤销操作主要是以下几块: 撤销已经提交的Commit. 对已经通过git add加入Stage的文件,进行unstage操作. 对已经是Untracked却 ...
- 『现学现忘』Git基础 — 36、标签tag(一)
目录 1.标签介绍 2.列出标签 3.创建标签 (1)标签的分类 (2)附注标签 (3)轻量标签 4.后期打标签 1.标签介绍 软件的某个发行版本所对应的,其实就是软件开发过程中,某一个阶段的最后一次 ...
- 『现学现忘』Git基础 — 37、标签tag(二)
目录 5.共享标签 6.删除标签 7.修改标签指定提交的代码 8.标签在.git目录中的位置 9.本文中所使用到的命令 提示:接上一篇文章内容. 5.共享标签 默认情况下,git push 命令并不会 ...
- git各种撤销操作
撤销git add: git reset HEAD+路径 或者git reset --+路径 撤销commit: 1.回退到具体的嘻哈值 git reset --hard 2.回退后仍包含本地 ...
随机推荐
- WPF管理系统自定义分页控件 - WPF特工队内部资料
最近做一个演示的管理系统项目,需要用到分页控件,在网上找了很多,依然找到与UI模版匹配的,最后干脆自己写一个. 分页控件分析: 1.分页控件分简单显示和复杂显示两种: 2.包含上一页.下一页以及页码明 ...
- 指定的 CGI 应用程序遇到错误,服务器终止了该进程。
遇到这种错误只需要把这个项目的Cookies删除再重新启动就行了
- sublime text 3 package Install 安装失败解决方法
失败原因为官网地址被墙,导致channel_v3文件无法访问. 解决方法: 点击Preferences——>Package Settings——>Package Control——> ...
- SpringCloud入门
一. 什么是 SpringCloud 什么是 SpringCloud:是一个服务治理平台,提供了一些服务框架.包含了:服务注册与发现.配置中心.消息中心 .负载均衡.数据监控等等. ...
- 微软开源大规模数据处理项目 Data Accelerator
微软开源了一个原为内部使用的大规模数据处理项目 Data Accelerator.自 2017 年开发以来,该项目已经大规模应用在各种微软产品工作管道上. 据微软官方开源博客介绍,Data Accel ...
- Linux环境下vi/vim编辑器常用命令
使用vi文本编辑器 配置文件是Linux系统中的显著特征之一,其作用有点类似于Windows系统中的注册表,只不过注册表是集中管理,而配置文件采用了分散的自由管理方式.那么如何使用Linux字符操作界 ...
- 2018-2019-2 网络对抗技术 20162329 Exp1 PC平台逆向破解
目录 1.实践目标 2.实验内容 2.1 手工修改可执行文件,改变程序执行流程,直接跳转到getShell函数. 2.2 利用foo函数的Bof漏洞,构造一个攻击输入字符串,覆盖返回地址,触发getS ...
- [CF1093E]Intersection of Permutations
[CF1093E]Intersection of Permutations 题目大意: 给定两个长度为\(n(n\le2\times10^5)\)的排列\(A,B\).\(m(m\le2\times1 ...
- js 原生转json 可以v8中运行
// load("D:/jsontest.js"); function test1(vvv) { print(vvv); } //把json str 转 json obj func ...
- margin与padding的bug
1.在页面布局时,值对于块元素来说,相邻的两个兄弟块元素间的margin-top与上一个兄弟的margin-bottom重合时, 解决办法:对其中一个块元素中设置 display:inline- ...