开始的时候

  git config --global user.name "Your Name"
git config --global user.email "email@example.com"

查看你的信息

 git config --list

克隆仓库

 git clone  [url]

版本库

 mkdir learngit
cd learngit
pwd
/Users/michael/learngit
初始化:
git init

文件添加到版本库

 #创建文件
vim readme.txt
cat readme.txt
Git is a version control system.
Git is free software.
#文件添加到仓库
git add readme.txt
#把文件提交到仓库
git commit -m "wrote a readme file"

跳过使用暂存区(不适用git  add)

 git   commit -a -m  "说明的文字"

 只需要加个-a选项

查看状态

git  status  #查看状态
git diff readme.txt #比较文件上次修改的东西,,比较当前工作目录中的文件和暂存区域快照之间的差异,只是显示尚未暂存的改动
git diff --cached #已经暂存的将要添加到下次提交里的内容
  git  status
[root@pup learngit]# git status
# On branch master
nothing to commit (working directory clean)
修改文件后在查看
[root@pup learngit]# vim readme.txt
[root@pup learngit]# git status
# On branch master
# Changed but not updated:
# (use "git add <file>..." to update what will be committed)
# (use "git checkout -- <file>..." to discard changes in working directory)
#
# modified: readme.txt
#
# Untracked files:
# (use "git add <file>..." to include in what will be committed)
#
# .readme.txt.swp
no changes added to commit (use "git add" and/or "git commit -a")
[root@pup learngit]# git diff readme.txt
diff --git a/readme.txt b/readme.txt
index 4dfbf00..a6cb86a
--- a/readme.txt
+++ b/readme.txt
@@ -, +, @@
Git is a distributed version control system.
Git is free software distributed under the GPL
-
+

移除文件(从暂存区中移除)

git   rm   文件   #会连带从工作目录中删除指定的文件
git rm -f 文件 #删除之前修改过并且已经放到暂存区域的文件,不可恢复
git rm --cached 文件 #从暂存区域移除但是文件依然保留在当前工作目录中

移动文件(给文件改名字)

git mv README.md README
相当于
$ mv README.md README
$ git rm README.md
$ git add README

版本回退

 git  log  #命令显示从最近到最远的提交日志
git log --pretty=oneline #简洁的显示
git log -p -2 #-p 每次提交的内容差异,-2最近两次提交
在Git中,用HEAD表示当前版本,上一个版本就是HEAD^,上上一个版本就是HEAD^^,一般写成HEAD~
git reset --hard HEAD^ #回退到上一个版本
git reflog查看命令历史,以便确定要回到未来的哪个版本
回退:
git reset --hard commit_id
回到未来
git reset --hard commit_id

定制要显示的记录格式

git log --pretty=format   格式

例如:

git log --pretty=format:"%h - %an, %ar : %s"

工作区和暂存区概念理解

 git add命令实际上就是把要提交的所有修改放到暂存区(Stage),然后,执行git commit就可以一次性把暂存区的所有修改提交到分支。
前面讲了我们把文件往Git版本库里添加的时候,是分两步执行的: 第一步是用git add把文件添加进去,实际上就是把文件修改添加到暂存区; 第二步是用git commit提交更改,实际上就是把暂存区的所有内容提交到当前分支。
从来没被添加过的文件状态是Untracked

具体过程如下:

刚开始:参考这里

文件修改提交

最后

撤销修改

1,当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时

 git checkout -- file
git checkout -- readme.txt

2当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,返回到以前的工作区的内容

git reset HEAD  文件   #从暂存区返回到工作区

3提交了(commit)了但是可能漏了几个文件没有(add)添加或者提交信息写错了,这是运行

git commit --amend     #尝试重新提交

eg

$ git commit -m 'initial commit'
$ git add forgotten_file
$ git commit --amend
最终你只会有一个提交 - 第二次提交将代替第一次提交的结果。
												

git常用命令的更多相关文章

  1. git常用命令(持续更新中)

    git常用命令(持续更新中) 本地仓库操作git int                                 初始化本地仓库git add .                       ...

  2. Git 常用命令详解

    Git 是一个很强大的分布式版本管理工具,它不但适用于管理大型开源软件的源代码(如:linux kernel),管理私人的文档和源代码也有很多优势(如:wsi-lgame-pro) Git 的更多介绍 ...

  3. Git 常用命令大全

    Git常用操作命令: 1) 远程仓库相关命令 检出仓库:$ git clone git://github.com/jquery/jquery.git 查看远程仓库:$ git remote -v 添加 ...

  4. Git常用命令总结

    Git常用命令总结 git init      在本地新建一个repo,进入一个项目目录,执行git init,会初始化一个repo,并在当前文件夹下创建一个.git文件夹.   git clone ...

  5. GIT常用命令备忘

    Git配置 git config --global user.name "storm" git config --global user.email "stormzhan ...

  6. Git 常用命令2

    Git 常用命令 Git 是一个很强大的分布式版本控制系统.它不但适用于管理大型开源软件的源代码,管理私人的文档和源代码也有很多优势. Git常用操作命令: 1) 远程仓库相关命令 检出仓库:$ gi ...

  7. git常用命令-基本操作

    git常用命令-基本操作 1)      新增文件 新增了Test_1.java git add Test_1.java git commit –m “新增了Test_1.java” git push ...

  8. 转收藏:Git常用命令速查表

    一. Git 常用命令速查 git branch 查看本地所有分支git status 查看当前状态 git commit 提交 git branch -a 查看所有的分支git branch -r ...

  9. git常用命令,git版本控制和Xcode结合使用,用Xcode提交到github,github客户端使用

    1.git常用命令 查看命令: 1.git --help 查看git所有命令 2.git clone -help 查看git clone命令的细节 3.git config -l   查看当前所有配置 ...

  10. Git 常用命令详解(二)

    Git 是一个很强大的分布式版本管理工具,它不但适用于管理大型开源软件的源代码(如:linux kernel),管理私人的文档和源代码也有很多优势(如:wsi-lgame-pro) Git 的更多介绍 ...

随机推荐

  1. Windows10应用Docker部署DoNet Core

    Win10和Mac稳定版的Docker发布了,之前看了下徐磊老师的几篇Docker4Dotnet的文章http://devopshub.cn/2016/07/08/docker4dotnet-1-ov ...

  2. HTML5的新语义化的标签

    在HTML5之前采用HTML+CSS文档结构写法 [ID选择器说明 id选择器——用于标识页面上特定元素(比如站点导航.页眉.页脚)而且必须唯一; 也可以用来标识持久结构性元素(如主导航.内容区域)] ...

  3. 安装cocoapods以及更新cocoapods

    安装 1.设置ruby的软件源 这是因为ruby的软件源rubygems.org因为使用亚马逊的云服务,被我天朝屏蔽了,需要更新一下ruby的源,过程如下: gem sources -l #(查看当前 ...

  4. GCD的相关函数使用

    GCD 是iOS多线程实现方案之一,非常常用 英文翻译过来就是伟大的中枢调度器,也有人戏称为是牛逼的中枢调度器 是苹果公司为多核的并行运算提出的解决方案 1.一次性函数 dispatch_once 顾 ...

  5. Laravel大型项目系列教程(五)之文章和标签管理

    一.前言 本节教程将大概完成文章和标签管理以及标签关联. 二.Let's go 1.文章管理 首先创建管理后台文章列表视图: $ php artisan generate:view admin.art ...

  6. jqgrid+bootstrap样式实践

    jqgrid+bootstrap样式实践,报错数据加载,选中,删除等功能 需要引入的样式 bootstrap.min.css ui.jqgrid.css 需要引入的JS jquery.min.js b ...

  7. js动态获取子复选项并设计全选及提交

    在做项目的时候,会遇到根据父选项,动态的获取子选项,并列出多个复选框,提交时,把选中的合并成一个字符提交后台 本章将讲述如何通过js控制实现该操作: 1:设计父类别为radio,为每一个radio都加 ...

  8. JQuery 了解

    jQuery是什么?为什么是这样?怎么用? jQuery是对JavaScript的一种封装,是一个常用功能库.javascript是做什么的jquery就是做啥的.用它主要使写js更简便而强大,有些功 ...

  9. Hibernate 系列 04 - Hibernate 配置相关的类

    引导目录: Hibernate 系列教程 目录 前言: 通过上一篇的增删改查小练习之后,咱们大概已经掌握了Hibernate的基本用法. 我们发现,在调用Hibernate API的过程中,虽然Hib ...

  10. mysql select日期格式

    mysql表中datatime类型存储为2016-01-10,C#直接select 后,在datatable里面看,变成01/10/2016,需要还原回去,使用select DATE_FORMAT(列 ...