首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >【git系列】简单入门git命令一

【git系列】简单入门git命令一

作者头像
沁溪源
发布2020-12-01 10:32:50
发布2020-12-01 10:32:50
6240
举报
文章被收录于专栏:沁溪源沁溪源

配置用户信息

  • 命令: 配置用户名:git config --global user.name 'your_name' 配置邮箱:git config --global user.email 'your_email@***.com' 说明 config后面的作用域:
  1. 如果缺省,则默认使用global;
  2. local:只对某个仓库有效,即需要在项目仓库中设置;
  3. global: 对当前用户所有仓库有效
  4. system: 对系统所有登录的用户有效
  • 显示配置信息 git config --list --local/global/system

建立git仓库

主要分为两种场景:基于本地已存在的项目代码纳入git管理和新建的项目直接用git管理

  • 已存在的项目代码
代码语言:javascript
复制
cd /项目代码存在的目录
git init
  • 新建项目
代码语言:javascript
复制
git /新建项目的文件夹
git init your_project #会在当前路径下创建和项目名称相同的文件夹
cd your_project

示例:

代码语言:javascript
复制
qxy@qxy IdeaProjects % git init git_learn
Initialized empty Git repository in /Users/qxy/IdeaProjects/git_learn/.git/
qxy@qxy IdeaProjects % cd git_learn 
qxy@qxy git_learn % ls -al
total 0
drwxr-xr-x   3 qxy  staff   96 11 29 15:14 .
drwxr-xr-x  11 qxy  staff  352 11 29 15:14 ..
drwxr-xr-x  10 qxy  staff  320 11 29 15:14 .git

状态简览

命令:git status 使用git status -s 命令或 git status --short 命令,会得到一种格式更为紧凑的输出。 示例:

代码语言:javascript
复制
git status -s 
M README
MM Rakefile
A lib/git.rb
M lib/simplegit.rb 
?? LICENSE.txt

说明:

  • 新添加的未跟踪文件前面有 ?? 标记;
  • 新添加到暂存区中的文件前面有 A 标记;
  • 修改过的文件前面有M标记。
  • 输出中有两栏,左栏指明了暂存区的状态,右栏指明了工作区的状态。 例如,上面的状态报告显示: README 文件 在工作区已修改但尚未暂存,而 lib/simplegit.rb 文件已修改且已暂存。 Rakefile 文件已修改,暂存后又作了修改,因此该文件的修改中既有已暂存的部分,又有未暂存的部分。

暂存区

区分几个概念: 工作目录:工作目录中的文件主要分为:已跟踪和未跟踪

  1. 已跟踪:已跟踪的文件是指那些被纳入了版本控制的文件。在上一次快照中有它们的记录,在工作一段时间后, 它们的状态可能是未修改已修改已放入暂存区简而言之,已跟踪的文件就是 Git 已经知道的文件,或者理解为已经执行过git add 命令,将文件存入暂存区中
  2. 未跟踪:工作目录中除已跟踪文件外的其它所有文件都属于未跟踪文件,它们既不存在于上次快照的记录中,也没有被放入暂存区。

初次克隆某个仓库的时候,工作目录中的所有文件都属于已跟踪文件,并处于未修改状态,因为 Git 刚刚检出了它们, 而你尚未编辑过它们。

  • 跟踪新文件或者暂存已修改文件 命令:git add <files> 参数:git add命令使用文件或目录的路径作为参数;如果参数是目录的路径,该命令将递归地跟踪该目录下的所有文件。 这是个多功能命令:可以用它开始跟踪新文件,或者把已跟踪的文件放到暂存区,还能用于合并时把有冲突的文件标记为已解决状态等
  • 示例: 新建README.md文件
代码语言:javascript
复制
> git status   
On branch master

No commits yet

Untracked files:
  (use "git add <file>..." to include in what will be committed)
	README.md

nothing added to commit but untracked files present (use "git add" to track)

状态命令中可以看到新建的 README.md文件出现在 Untracked files 下面,说明该文件是未跟踪状态。 未跟踪的文件意味着 Git 在之前的快照(提交)中没有这些文件;Git 不会自动将之纳入跟踪范围,除非你明明白白地告诉它“我需要跟踪该文 件”。

  • 跟踪新文件至暂存区
代码语言:javascript
复制
>  git add README.md 
//使用命令查看状态
> git status
On branch master

No commits yet

Changes to be committed:
  (use "git rm --cached <file>..." to unstage)
	new file:   README.md

运行git status命令,会看到文件已被跟踪,并处于暂存状态. 只要在 Changes to be committed这行下面的,就说明是已暂存状态。 如果此时提交,那么该文件在你运行git add时的版本将被留存在后续的历史记录中。

代码语言:javascript
复制
> git commit -m'new file'  
[master (root-commit) b0027c5] new file
 1 file changed, 128 insertions(+)
 create mode 100644 README.md
  • 暂存已修改的文件 上面已经把README.md文件提交,下面对他进行一下修改,再使用git status命令查看;
代码语言:javascript
复制
> git status
On branch master
Changes not staged for commit:
  (use "git add <file>..." to update what will be committed)
  (use "git restore <file>..." to discard changes in working directory)
	modified:   README.md

no changes added to commit (use "git add" and/or "git commit -a")

文件README.md出现在Changes not staged for commit这行下面,说明已跟踪文件的内容发生了变化,但还没有放到暂存区。 要暂存这次更新,需要运行 git add命令。

提交更新

将暂存区的文件提交到本地仓库中。使用git commit. commit 命令后添加 -m 选项,将提交信息与命令放在同一行。 示例:

代码语言:javascript
复制
> git commit -m'new file'  
[master (root-commit) b0027c5] new file
 1 file changed, 128 insertions(+)
 create mode 100644 README.md

跳过使用暂存区域

Git 提供了一个跳过使用暂 存区域的方式, 只要在提交的时候,给 git commit 加上 -a 选项,Git 就会自动把所有已经跟踪过的文件暂存 起来一并提交,从而跳过git add步骤。 示例:

代码语言:javascript
复制
> git commit -m'new file'  
[master (root-commit) b0027c5] new file
 1 file changed, 128 insertions(+)
 create mode 100644 README.md

查看文件修改

  • 要查看尚未暂存的文件更新了哪些部分,不加参数直接输入git diff 此命令比较的是工作目录中当前文件和暂存区域快照之间的差异。 也就是修改之后还没有暂存起来的变化内容。
  • 若要查看已暂存的将要添加到下次提交里的内容,可以用 git diff --staged命令。 这条命令将比对已暂存文件与最后一次提交的文件差异.

示例1: 对REDAME.md文件新增两个空格。使用git diff命令查看不同。

代码语言:javascript
复制
> git diff
diff --git a/README.md b/README.md
index 8a970d2..5c81e3c 100644
--- a/README.md
+++ b/README.md
@@ -8,6 +8,8 @@
 
 </div>
 
+
+
 #### 项目简介

示例2: 将示例1提交,然后再次对README.md 文件修改,然后添加到暂存区,使用git diff --staged命令对比修改内容:

代码语言:javascript
复制
>git diff  --staged
diff --git a/README.md b/README.md
index 5c81e3c..48b3fe1 100644
--- a/README.md
+++ b/README.md
@@ -8,7 +8,7 @@
 
 </div>
 
-
+对比git diff --staged
 
 #### 项目简介

可以明显看到结果是减少一行空格,并新增文字:对比git diff --staged

总结

划重点啦,大家要简单区别:工作目录,暂存区,本地仓库等概念; 即无论文件是否处于未跟踪(新建)或者已跟踪(修改,删除等)状态,使用命令git add ,则将文件添加到暂存区; 使用命令git commit -m ‘’,则是将暂存区的文件提交到本地仓库(版本历史中存在记录)。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020/11/29 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 配置用户信息
  • 建立git仓库
  • 状态简览
  • 暂存区
  • 提交更新
    • 跳过使用暂存区域
  • 查看文件修改
  • 总结
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档