Git 简明教程

Git - Perform Changes

Jerry 克隆了存储库并决定实现基本字符串操作。因此,他创建了 string.c 文件。添加内容后,string.c 将如下所示 −

#include <stdio.h>

int my_strlen(char *s)
{
   char *p = s;

   while (*p)
      ++p;

   return (p - s);
}

int main(void)
{
   int i;
   char *s[] =
   {
      "Git tutorials",
      "Tutorials Point"
   };

   for (i = 0; i < 2; ++i)

   printf("string lenght of %s = %d\n", s[i], my_strlen(s[i]));

   return 0;
}

他编译并测试了代码,一切都运行良好。现在,他可以安全地将这些更改添加到仓库中。

Git add 操作将文件添加到暂存区。

[jerry@CentOS project]$ git status -s
?? string
?? string.c

[jerry@CentOS project]$ git add string.c

Git在文件名之前显示一个问号。显然,这些文件不属于 Git,这就是为什么 Git 不知道如何处理这些文件。因此,Git 在文件名之前显示一个问号。

Jerry 已将文件添加到暂存区,git status 命令将显示暂存区中的文件。

[jerry@CentOS project]$ git status -s
A string.c
?? string

为了提交这些更改,他使用了 git commit 命令,后跟 -m 选项。如果我们省略 -m 选项。Git 将打开一个文本编辑器,我们可以在其中编写多行提交消息。

[jerry@CentOS project]$ git commit -m 'Implemented my_strlen function'

以上命令将生成以下结果 −

[master cbe1249] Implemented my_strlen function
1 files changed, 24 insertions(+), 0 deletions(-)
create mode 100644 string.c

提交后,为了查看日志详情,他运行 git log 命令。它将显示所有提交的信息,包括提交 ID、提交作者、提交日期和提交的 SHA-1 哈希。

[jerry@CentOS project]$ git log

以上命令将生成以下结果 −

commit cbe1249b140dad24b2c35b15cc7e26a6f02d2277
Author: Jerry Mouse <jerry@tutorialspoint.com>
Date: Wed Sep 11 08:05:26 2013 +0530

Implemented my_strlen function


commit 19ae20683fc460db7d127cf201a1429523b0e319
Author: Tom Cat <tom@tutorialspoint.com>
Date: Wed Sep 11 07:32:56 2013 +0530

Initial commit