[Git] 008 status 与 commit 命令的补充
本文的“剧情”承接 [Git] 007 三棵树以及向本地仓库加入第一个文件
1. 对 "status" 的补充
1.1 "status" 有个参数 "-s"
- 命令:
git status -s

- 没有消息使最好的消息
1.2 比较
git status -s显示的信息比git status简洁

1.3 不妨再添加一个文件

1.4 往 "note_01.txt" 中写入文本

1.5 查看

- 第 3 行开头红色的 "??" 说明 "note_01.txt" 还没有进行过 "add" 或 "commit" 操作
1.6 将 "note_01.txt" 加入暂存区后再查看

- 第 5 行开头绿色的 "A",说明 "note_01.txt" 已经被加到暂存区了
1.7 继续往 "note_01.txt" 中添加文本

1.8 再查看一下

- 第 3 行开头有绿色的 "A" 与红色的 "M"
- 绿色的 "A" 说明 "note_01.txt" 已经被加到暂存区了
- 红色的 "M" 说明工作区的 "note_01.txt" 又做了修改,与暂存区的 "note_01.txt" 不同了
2. 对 "commit" 的补充
2.1 "commit" 有个参数 "-m"
git commit -m "<message>"

- 知识点
- 有些版本用
git commit跳转,使用 "vi / vim" 编辑后,中文部分可能会乱码 - 使用
git commit -m "<message>"可以避免乱码
- 有些版本用
2.2 查看

分析
- 此时加入本地仓库的是暂存区的 "note_01.txt"
- 第 3 行的 "M" 前预留了一个位置;对比 "1.8" 的图,这个位置使留给 "A" 的
2.3 添加 & 提交
- 因为工作区的 "note_01.txt" 有了变动,所以在“添加 & 提交”一次
- 提交过的文件,可以使用
git commit -am命令- "-am" 的 "a" 是 "all" 的意思
- 之前没有 "add"、"commit" 的文件不能用

2.4 提问时间
- 只做了一个很小的变动,不想 "commit" 怎么操作?
2.4.1 方法一
- 使用
git commit --amend - 此法可以把后一次提交并入前一次
- 但纪录中仍有两条
- 证据:"commit" 的次数不变,但哈希值会变
在之前的基础上加入一句'4. git commit -m "<message>" 加入仓库'

- 这里犯了个错误:我 "commit" 之前忘记 "add" 了;成功版见 [Git] 010 对 [Git 008] 的补充:实现 commit 不计次数
$ git commit --amend


2.4.2 方法二
- 方法二是方法一的进阶版
使用:
git commit --amend --no-edit- 此法可以把后一次提交并入前一次,并且可以不写“注释”
- 但纪录中仍有两条
- 证据:"commit" 的次数不变,但哈希值会变
同方法一,这里犯了个错误:我 "commit" 之前忘记 "add" 了;成功版见 [Git] 010 对 [Git 008] 的补充:实现 commit 不计次数

2.5 有参数可以在第一次 "commit" 时不写“注释”
- 挖个坑,日后填平
- 坑号编码:Git08-1
[Git] 008 status 与 commit 命令的补充的更多相关文章
- [Git] 011 checkout 与 reset 命令的补充
1. git checkout -- <file> 的示意 2. "checkout" 的补充 2.1 git checkout <branch_name> ...
- git 查看对比分支commit命令笔记
git log newheader(branch1) ^release(branch2) -- branch1 上比branch2多的commit 注意brnach2后面要--
- git查看和操作commit命令
git reflog 显示所有branch的commit,包括commit和reset,以及已删除的commit.而git log只显示当前branch的commit,不包括已删除的commit gi ...
- [Git] 010 对 [Git 008] 的补充:实现 commit 不计次数
回顾:[Git] 008 status 与 commit 命令的补充 的 "2.4" [Git 008] 的 "2.4" 使用 git commit --ame ...
- Git命令汇总(补充篇)
上一篇<Git命令汇总基础篇>总结了使用Git的基本命令,这一篇作为补充主要给大家讲一些平时使用中的技巧和总结 . 学会了这些命令,已经基本解决了使用Git中大部分问题. 1.gitign ...
- Git的add、commit、push命令
简单的代码提交流程1.git status 查看工作区代码相对于暂存区的差别2.git add . 将当前目录下修改的所有代码从工作区添加到暂存区 . 代表当前目录3.git commit -m ‘注 ...
- git commit命令
git commit 主要是将暂存区里的改动提交到本地的版本库.每次使用git commit 命令我们都会在本地版本库生成一个40位的哈希值,这个哈希值也叫commit-id. commit-id在版 ...
- git学习------>git commit命令的默认编辑器的修改
今天在新同事的电脑上,用git commit命令帮新同事提交代码的时候,编辑完commit的信息后,居然不记得怎么退出了.蛋疼. 后来百度了一下,原来此时是进入GUN nano编辑器.在这里可以添加你 ...
- Git 基本概念及常用命令
一.基本概念 文件的三种状态:(任何一个文件在git中都有以下三种状态) 1) 已提交(committed):表示该文件已经被安全地保存在本地数据库中了. 2) 已修改(modified):表示修改了 ...
随机推荐
- jquery.fancybox.js 解决只加载一次的问题
问题描述:有一块图片区域,页面第一次加载的时候jQuery(".fancybox-button").fancybox({}); 使用ajax上传成功后显示在图片区域,再次jQuer ...
- php内置函数分析之array_diff_assoc()
static void php_array_diff_key(INTERNAL_FUNCTION_PARAMETERS, int data_compare_type) /* {{{ */ { uint ...
- php内置函数分析之array_combine()
PHP_FUNCTION(array_combine) { HashTable *values, *keys; uint32_t pos_values = ; zval *entry_keys, *e ...
- larval 使用redis做缓存
1.存redis 使用setex命令可以同时设置数据和保存时间 $data = [ 'name'=>zhangsan, 'age' => 28, 'sex' => 1 ]; Redi ...
- linux运维、架构之路-redis集群
一.介绍 redis cluster 3.0之后的功能,至少需要3(Master)+3(Slave)才能建立集群,是无中心的分布式存储架构,可以在多个节点之间进行数据共享,解决了 ...
- 3D世界变换
一直弄不清3D场景中scaleOrientation的作用,还有scale.orientation(roation).translation的顺序问题,以往都是试图查一下,关于前者网上几乎找不到什么清 ...
- react native 之 AsyncStorage
新版本中不时从react-native导入了,而是 react-native-async-storage 使用static setItem(key: string, value: string, [c ...
- 对象数组(JSON) 根据某个共同字段 分组
1.在前端页面用js处理 转载https://www.cnblogs.com/rysinal/p/5834446.html 为了第二种方法对比,特意把id 转化为pid var arr = [ {&q ...
- 【后台管理系统】—— Ant Design Pro页面相关(一)
一.List列表形式 import React, { PureComponent } from 'react'; import { findDOMNode } from 'react-dom'; im ...
- 数位dp好题整理+自己wa过的细节记录
花(fa)神的数论题 三倍经验:烦人的数学作业 windy数 手机号码 同类分布(博客先鸽着) 板子固然好,细节无限多. 花式wa题法,警示后来人. 1.手残害人不浅 (蒟蒻的我掉坑里不止一次) 2. ...