Git 基本操作

Git 的工作就是创建和保存你的项目的快照及与之后的快照进行对比。本章将对有关创建与提交你的项目的快照的命令作介绍。

获取与创建项目命令

git init

用 git init 在目录中创建新的 Git 仓库。 你可以在任何时候、任何目录中这么做,完全是本地化的。

在目录中执行 git init,就可以创建一个 Git 仓库了。比如我们创建 zqxt 项目:$ mkdir zqxt

$ cd zqxt

$ git init

Initialized empty Git repository in /www/zqxt/.git/

# 在 /www/zqxt/.git/ 目录初始化空 Git 仓库完毕。

现在你可以看到在你的项目目录中有个 .git 的子目录。 这就是你的 Git 仓库了,所有有关你的此项目的快照数据都存放在这里。ls -a

....git

git clone

使用 git clone 拷贝一个 Git 仓库到本地,让自己能够查看该项目,或者进行修改。

如果你需要与他人合作一个项目,或者想要复制一个项目,看看代码,你就可以克隆那个项目。 执行命令:git clone [url]

[url] 为你想要复制的项目,就可以了。

例如我们克隆 Github 上的项目:$ git clone git://github.com/schacon/simplegit.git

Initialized empty Git repository in /private/tmp/simplegit/.git/

remote: Counting objects: 100, done.

remote: Compressing objects: 100% (86/86), done.

remote: Total 100 (delta 35), reused 0 (delta 0)

Receiving objects: 100% (100/100), 9.51 KiB, done.

Resolving deltas: 100% (35/35), done.

$ cd simplegit/

$ ls

README Rakefile lib

上述操作将复制该项目的全部记录。$ ls -a

. .. .git README Rakefile lib

$ cd .git

$ ls

HEAD description info packed-refs

branches hooks logs refs

config index objects

默认情况下,Git 会按照你提供的 URL 所指示的项目的名称创建你的本地项目目录。 通常就是该 URL 最后一个 / 之后的项目名称。如果你想要一个不一样的名字, 你可以在该命令后加上你想要的名称。

基本快照

Git 的工作就是创建和保存你的项目的快照及与之后的快照进行对比。本章将对有关创建与提交你的项目的快照的命令作介绍。

git add

git add 命令可将该文件添加到缓存,如我们添加以下两个文件:$ touch README

$ touch hello.php

$ ls

READMEhello.php

$ git status -s

?? README

?? hello.php

$

git status 命令用于查看项目的当前状态。

接下来我们执行 git add 命令来添加文件:$ git add README hello.php

现在我们再执行 git status,就可以看到这两个文件已经加上去了。$ git status -s

A README

A hello.php

$

新项目中,添加所有文件很普遍,可以在当前工作目录执行命令:git add .。

现在我们改个文件,再执行一下 git status:$ vim README

$ git status -s

AM README

A hello.php

"AM" 状态的意思是,这个文件在我们将它添加到缓存之后又有改动。改动后我们在执行 git add 命令将其添加到缓存中:$ git add .

$ git status -s

A README

A hello.php

当你要将你的修改包含在即将提交的快照里的时候,需要执行 git add。

git status

git status 以查看在你上次提交之后是否有修改。

我演示该命令的时候加了 -s 参数,以获得简短的结果输出。如果没加该参数会详细输出内容:$ git status

On branch master

Initial commit

Changes to be committed:

(use "git rm --cached ..." to unstage)

new file: README

new file: hello.php

git diff

执行 git diff 来查看执行 git status 的结果的详细信息。

git diff 命令显示已写入缓存与已修改但尚未写入缓存的改动的区别。git diff 有两个主要的应用场景。尚未缓存的改动:git diff

查看已缓存的改动: git diff --cached

查看已缓存的与未缓存的所有改动:git diff HEAD

显示摘要而非整个 diff:git diff --stat

在 hello.php 文件中输入以下内容:<?php

echo 'www.ziqiangxuetang.com';

?>$ git status -s

A README

AM hello.php

$ git diff

diff --git a/hello.php b/hello.php

index e69de29..d1a9166 100644

--- a/hello.php

+++ b/hello.php

@@ -0,0 +1,3 @@

+<?php

+echo 'www.ziqiangxuetang.com';

+?>

git status显示你上次提交更新至后所更改或者写入缓存的改动, 而 git diff 一行一行地显示这些改动具体是啥。

接下来我们来查看下 git diff --cached 的执行效果:$ git add hello.php

$ git status -s

A README

A hello.php

$ git diff --cached

diff --git a/README b/README

new file mode 100644

index 0000000..704cce7

--- /dev/null

+++ b/README

@@ -0,0 +1 @@

+ziqiangxuetang.com

diff --git a/hello.php b/hello.php

new file mode 100644

index 0000000..d1a9166

--- /dev/null

+++ b/hello.php

@@ -0,0 +1,3 @@

+<?php

+echo 'www.ziqiangxuetang.com';

+?>

git commit

使用 git add 命令将想要快照的内容写入了缓存, 而执行 git commit 记录缓存区的快照。

Git 为你的每一个提交都记录你的名字与电子邮箱地址,所以第一步需要配置用户名和邮箱地址。$ git config --global user.name 'ziqiangxuetang'

$ git config --global user.email w3c@ziqiangxuetang.com

接下来我们写入缓存,并提交对 hello.php 的所有改动。在首个例子中,我们使用 -m 选项以在命令行中提供提交注释。$ git add hello.php

$ git status -s

A README

A hello.php

$ git commit -m 'test comment from ziqiangxuetang.com'

[master (root-commit) 85fc7e7] test comment from ziqiangxuetang.com

2 files changed, 4 insertions(+)

create mode 100644 README

create mode 100644 hello.php

现在我们已经记录了快照。如果我们再执行 git status:$ git status

# On branch master

nothing to commit (working directory clean)

以上输出说明我们在最近一次提交之后,没有做任何改动,是一个"干净的工作目录"。

如果你没有设置 -m 选项,Git 会尝试为你打开一个编辑器以填写提交信息。 如果 Git 在你对它的配置中找不到相关信息,默认会打开 vim。屏幕会像这样: # Please enter the commit message for your changes. Lines starting # with '#' will be ignored, and an empty message aborts the commit. # On branch master # Changes to be committed: # (use "git reset HEAD ..." to unstage) # # modified: hello.php # ~ ~ ".git/COMMIT_EDITMSG" 9L, 257C

如果你觉得 git add 提交缓存的流程太过繁琐,Git 也允许你用 -a 选项跳过这一步。命令格式如下:git commit -a

如:$ git commit -am 'changes to hello file'

[master 78b2670] changes to hello file

1 files changed, 2 insertions(+), 1 deletions(-)

git reset HEAD

git reset HEAD 命令用于取消缓存已缓存的内容。

这里我们有两个最近提交之后又有所改动的文件。我们将两个都缓存,并取消缓存其中一个。$ git status -s

M README

M hello.php

$ git add .

$ git status -s

M README

M hello.pp

$ git reset HEAD -- hello.php

Unstaged changes after reset:

M hello.php

$ git status -s

M README

M hello.php

现在你执行 git commit 将只记录 README 文件的改动,并不含现在并不在缓存中的 hello.rb。

git rm

git rm 将文件从缓存区中移除。

如我们删除 hello.php文件:$ git rm hello.php

rm 'hello.php'

$ ls

README

默认情况下,git rm file 会将文件从缓存区和你的硬盘中(工作目录)删除。 如果要在工作目录中留着该文件,可以使用命令:git rm --cached。

git mv

git mv 命令做得所有事情就是 git rm --cached, 重命名磁盘上的文件,然后再执行 git add 把新文件添加到缓存区。因此,虽然有 git mv 命令,但它有点多余 。

git status怎么操作_Git 基本操作相关推荐

  1. git status怎么操作_git操作-方向对了,就不怕路远了!-51CTO博客

    git介绍 与svn不同的是,svn是集中式管理,当自己主机上修改了文件,必须提交到服务器,其他人才能提交,不然冲突 git是自己本机也可以作为仓库,也有当做服务器,分布式管理 安装: bash-co ...

  2. git status怎么操作_新手 git 简明操作指南

    在工作中,我们可能需要采用 git 作为版本控制工具.所以对 git 的基本操作需要非常熟练,以至于我们能够应付工作上的需求.当然这里推荐一篇博文廖雪峰的git教程,有更详细的介绍.我这里对git的一 ...

  3. git status清空_Git常见命令和遇到问题的解决办法

    一.Git整体理解 Git代码管理是分布式管理方式系统,优点在于其极高的安全性和非常强大的分支管理. image.png 工作区(working directory): 就是本地的代码区,电脑能看到的 ...

  4. git stash 强制恢复_git操作与分支管理规范

    git操作与分支管理规范 一.git操作规范 git操作流程数据流图 Remote:远程主仓库 Repository:本地仓库 Index:Git追踪树,暂存区 workspace:本地工作区 代码正 ...

  5. git版本回退命令_Git学习版本回退和管理文件的修改及删除操作

    版本回退 前面我们成功的提交了一次mygit.txt,下面咱对它进行修改,内容如下: Hello Git Git is so easy. 然后用git status来跟踪该文件的状态: 可以看到hel ...

  6. git 小乌龟 更新分支_git常用操作

    Git 是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目. Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件. Git ...

  7. git reset 怎么还原_git reset --hard 操作后的数据恢复

    在进行正文之前先简单介绍下git reset 命令 git reset git reset 命令用于改变当前的仓库状态,简单的场景用例:假设一次修改了两个文件,然而需要对这两个文件分别进行两次提交,在 ...

  8. git如何添加远程主机_Git远程操作详解

    Git是目前最流行的版本管理系统,学会Git几乎成了开发者的必备技能. Git有很多优势,其中之一就是远程操作非常简便.本文详细介绍5个Git命令,它们的概念和用法,理解了这些内容,你就会完全掌握Gi ...

  9. git回退历史版本无法上传_Git实用教程(四) | Git本地库操作(查看提交历史、版本前进回退)...

    Git实用教程专栏回顾 Git实用教程(一) | 为什么需要版本控制?(以嵌入式项目开发为例) Git实用教程(二) | Git简介及安装详解 Git实用教程(三) | Git本地库操作(仓库初始化. ...

最新文章

  1. sping中注解事务的应用
  2. 看懂类图——UML类图基础
  3. 【Android游戏开发之八】游戏中添加音频-详解MediaPlayer与SoundPool的利弊以及各个在游戏中的用途!...
  4. Scala学习之特殊符号,及函数
  5. mysql 字段排重_MySQL 根据单个、多个字段排重
  6. 理解数据库与数据模型的概念
  7. 最全的Vim操作快捷键
  8. 数据结构题集(C语言版)——第一张 绪论(1~6)
  9. 代码实现21种常见设计模式
  10. Ruby语言入门之Hello world
  11. firefox改html内容,Firefox 中的 HTML5 音视频
  12. 搜集各种稀奇古怪的编码
  13. vuepress-theme-reco@1.x 解决博客首页 与 仓库README不兼容问题
  14. 化工厂人员定位详细解决方案
  15. 2015最新苹果开发者账号(299$)申请流程
  16. idc服务器硬件,IDC基础:服务器机柜的设备介绍
  17. 为智能汽车装上“云发动机”
  18. 嵌入式优秀资源网址整理
  19. 新加坡环球影城:新加坡亲子游一日游好去处
  20. Llinux装逼命令大全

热门文章

  1. 三色标记原理,我给应聘者问懵了...
  2. 一文掌握GaussDB(DWS) SQL进阶技能:全文检索
  3. Centos7使用Yum安装高版本的LNMP
  4. AIOps产品与架构浅析
  5. 【Python3网络爬虫开发实战】1.3.1-lxml的安装
  6. 【华为云实战开发】4.如何使用TortoiseGit进行云端代码托管
  7. 玩游戏提示计算机性能过低,如果玩游戏的fps低怎么办?八个问题和九个解决方案...
  8. 下载的字幕php是什么格式的,mkv是什么文件格式
  9. 红橙Darren视频笔记 builder设计模式 navigationbar 导航栏第二版
  10. tinypng 批量处理插件_分享六款逆天的Excel插件,高效处理数据必备!低调使用...