git status怎么操作_Git 基本操作
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 基本操作相关推荐
- git status怎么操作_git操作-方向对了,就不怕路远了!-51CTO博客
git介绍 与svn不同的是,svn是集中式管理,当自己主机上修改了文件,必须提交到服务器,其他人才能提交,不然冲突 git是自己本机也可以作为仓库,也有当做服务器,分布式管理 安装: bash-co ...
- git status怎么操作_新手 git 简明操作指南
在工作中,我们可能需要采用 git 作为版本控制工具.所以对 git 的基本操作需要非常熟练,以至于我们能够应付工作上的需求.当然这里推荐一篇博文廖雪峰的git教程,有更详细的介绍.我这里对git的一 ...
- git status清空_Git常见命令和遇到问题的解决办法
一.Git整体理解 Git代码管理是分布式管理方式系统,优点在于其极高的安全性和非常强大的分支管理. image.png 工作区(working directory): 就是本地的代码区,电脑能看到的 ...
- git stash 强制恢复_git操作与分支管理规范
git操作与分支管理规范 一.git操作规范 git操作流程数据流图 Remote:远程主仓库 Repository:本地仓库 Index:Git追踪树,暂存区 workspace:本地工作区 代码正 ...
- git版本回退命令_Git学习版本回退和管理文件的修改及删除操作
版本回退 前面我们成功的提交了一次mygit.txt,下面咱对它进行修改,内容如下: Hello Git Git is so easy. 然后用git status来跟踪该文件的状态: 可以看到hel ...
- git 小乌龟 更新分支_git常用操作
Git 是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目. Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件. Git ...
- git reset 怎么还原_git reset --hard 操作后的数据恢复
在进行正文之前先简单介绍下git reset 命令 git reset git reset 命令用于改变当前的仓库状态,简单的场景用例:假设一次修改了两个文件,然而需要对这两个文件分别进行两次提交,在 ...
- git如何添加远程主机_Git远程操作详解
Git是目前最流行的版本管理系统,学会Git几乎成了开发者的必备技能. Git有很多优势,其中之一就是远程操作非常简便.本文详细介绍5个Git命令,它们的概念和用法,理解了这些内容,你就会完全掌握Gi ...
- git回退历史版本无法上传_Git实用教程(四) | Git本地库操作(查看提交历史、版本前进回退)...
Git实用教程专栏回顾 Git实用教程(一) | 为什么需要版本控制?(以嵌入式项目开发为例) Git实用教程(二) | Git简介及安装详解 Git实用教程(三) | Git本地库操作(仓库初始化. ...
最新文章
- sping中注解事务的应用
- 看懂类图——UML类图基础
- 【Android游戏开发之八】游戏中添加音频-详解MediaPlayer与SoundPool的利弊以及各个在游戏中的用途!...
- Scala学习之特殊符号,及函数
- mysql 字段排重_MySQL 根据单个、多个字段排重
- 理解数据库与数据模型的概念
- 最全的Vim操作快捷键
- 数据结构题集(C语言版)——第一张 绪论(1~6)
- 代码实现21种常见设计模式
- Ruby语言入门之Hello world
- firefox改html内容,Firefox 中的 HTML5 音视频
- 搜集各种稀奇古怪的编码
- vuepress-theme-reco@1.x 解决博客首页 与 仓库README不兼容问题
- 化工厂人员定位详细解决方案
- 2015最新苹果开发者账号(299$)申请流程
- idc服务器硬件,IDC基础:服务器机柜的设备介绍
- 为智能汽车装上“云发动机”
- 嵌入式优秀资源网址整理
- 新加坡环球影城:新加坡亲子游一日游好去处
- Llinux装逼命令大全
热门文章
- 三色标记原理,我给应聘者问懵了...
- 一文掌握GaussDB(DWS) SQL进阶技能:全文检索
- Centos7使用Yum安装高版本的LNMP
- AIOps产品与架构浅析
- 【Python3网络爬虫开发实战】1.3.1-lxml的安装
- 【华为云实战开发】4.如何使用TortoiseGit进行云端代码托管
- 玩游戏提示计算机性能过低,如果玩游戏的fps低怎么办?八个问题和九个解决方案...
- 下载的字幕php是什么格式的,mkv是什么文件格式
- 红橙Darren视频笔记 builder设计模式 navigationbar 导航栏第二版
- tinypng 批量处理插件_分享六款逆天的Excel插件,高效处理数据必备!低调使用...