Git bash:

***创建本地版本库:

$ cd d:

$ mkdir git

$ cd git

$ mkdir test

$ git init   //初始化本地库

***创建文件并添加到版本库

1. 用除了记事本以外的文本编辑工具新建readme.txt, 保存成UTF8 without BOM

2. git add readme.txt   //文件添加到仓库

3. git commit -m "add readme.txt file"   //-m就相当于加label, 将文件提交到仓库

可以add几个文件后, 统一commit到版本库

***查看提交状态(未add)

1. vi readme.txt   //修改内容

2. git status //查看状态

3. git diff readme.txt  //查看修改细节

***版本回退

1. 修改文件并且已经add,commit的情况

* 还未关机:

$ git log --pretty=oneline    //查看所有的commit id,注意版本号前7位
       3628164fb26d48395383f8f31179f24e0882e1e0 append GPL
       ea34578d5496d7dd233c827ed32a8cd576c5ee85 add distributed
       cb926e7ea50ad11b8f9e909c05226233bf755030 wrote a readme file

$ git reset --hard HEAD^  //回到上一个版本    HEAD^可以替换成上面commit id的前7位

后悔了, 还想回到最新版本

$ git reset --hard 3628164

*已关机无法查看commit id时:

$ git reflog

***工作区和暂存区stage

$ git add readme.txt

$ git add LICENCE.txt

git add实际把提交的修改放到暂存区stage

git commit后

commit是把暂存区的内容放入版本库, 也就是说, 如果不执行add, 那么将不会被提交到版本库

***撤销修改:

不管在哪里修改, 包括工作区,stage, 如果想放弃当前修改都用

$ git checkout -- readme.txt     // 不管当前状态做过多少次修改,都回到最原始

也就是说恢复到最近一次add或commit的状态

所以分几种情况:

1. 在工作区的修改, 想撤销就直接

$ git checkout -- readme.txt

2. 工作区修改后, 已经add到stage的情况,需要把暂存区的修改恢复回工作区,再checkout

$ git reset HEAD readme.txt   //相当于从版本库里拽最新版本回stage

$ git checkout -- readme.txt

3. 工作区修改add到stage后commit到版本库master的情况, 需要先恢复版本库版本到上一个版本, 再从stage拽过来版本库里的版本,再在工作区进行checkout

$ git reset --hard HEAD^   // 版本库恢复 上一个版本

$ git reset HEAD readme.txt  //stage恢复到和版本库一个版本

$ git checkout -- readme.txt //工作区恢复修改前状态

***删除文件

如果在资源管理器里已经删除了某个文件, 或者用bash命令删除了个文件

$ rm test.txt

$ git status   //查看状态

1. 彻底删除文件

$ git rm test.txt

$ git commit -m "remove test.txt"

2. 如果想反悔:

$ git  checkout -- test.txt   //用版本库里的版本代替工作区的版本, 无论工作区是修改还是删除, 都可以一键还原

***创建远程仓库

1. 创建SSH Key, 会在users目录里创建.ssh文件夹,里面有id_rsa私钥文件和id_rsa.pub公钥文件:

$ ssh-keygen -t rsa -C "email@163.com"

2. 登录远程github网站--settings->SSH里添加公钥内容

3. 创建远程仓库 New->repository

4. 关联本地仓库和远程仓库

$ git remote add origin git@github.com:swportal/swportal.git   //第一个swportal是github账户名, 第二个是repository名

5. 查看远程仓库

$ git remote -v

6. 将本地仓库所有内容push到远程仓库

$ git push -u origin master

第一次推送时加-u, 以后再推送就直接

$ git push  origin master

***克隆远程库

1. 先在github创建一个新的仓库,同时勾选创建个README文件

2. 开始克隆出一个本地库

$ cd d:\git

$ git clone git@github.com:swportal/clonegit.git  //本地就有个仓库, 添加一个文件a.txt

$ git add a.txt

为了避免commit时 有出错信息显示please tell me who you are

$ git config  user.email "c.wuliying@samsung.com"

$ git commit -m "create a.txt"

创建远程库连接并push代码

$ git remote -v            查看远程origin库存在与否
    $ git push -u origin master

 

Github命令详解的更多相关文章

  1. Git初探--笔记整理和Git命令详解

    几个重要的概念 首先先明确几个概念: WorkPlace : 工作区 Index: 暂存区 Repository: 本地仓库/版本库 Remote: 远程仓库 当在Remote(如Github)上面c ...

  2. Git 常用命令详解

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

  3. Android Studio系列教程五--Gradle命令详解与导入第三方包

    Android Studio系列教程五--Gradle命令详解与导入第三方包 2015 年 01 月 05 日 DevTools 本文为个人原创,欢迎转载,但请务必在明显位置注明出处!http://s ...

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

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

  5. Git命令详解

    一个中文git手册:http://progit.org/book/zh/ 原文:http://blog.csdn.net/sunboy_2050/article/details/7529841 前面两 ...

  6. 【转】 Git 常用命令详解(二)----不错

    原文网址:http://blog.csdn.net/ithomer/article/details/7529022 Git 是一个很强大的分布式版本管理工具,它不但适用于管理大型开源软件的源代码(如: ...

  7. 【官方文档】Nginx模块Nginx-Rtmp-Module学习笔记(一) RTMP 命令详解

    源码地址:https://github.com/Tinywan/PHP_Experience 说明: rtmp的延迟主要取决于播放器设置,但流式传输软件,流的比特率和网络速度(以及响应时间“ping” ...

  8. (转)Memcached用法--参数和命令详解

    Memcached用法--参数和命令详解 1. memcached 参数说明: # memcached -h 1.1 memcached 的参数 常用参数 -p <num> 监听的TCP端 ...

  9. Protobuf 文件生成工具 Prototool 命令详解

    Protobuf 文件生成工具 Prototool 命令详解 简介 Prototool 是 Protobuf 文件的生成工具, 目前支持go, php, java, c#, object c 五种语言 ...

随机推荐

  1. Newlife商业源码分享

    [商业源码]生日大放送-Newlife商业源码分享 今天是农历六月二十三,是@大石头的生日,记得每年生日都会有很劲爆的重量级源码送出,今天Newlife群和论坛又一次疯狂了,吃水不忘挖井人,好的东西肯 ...

  2. NCache:最新发布的.NET平台分布式缓存系统

    NCache:最新发布的.NET平台分布式缓存系统在等待Microsoft完成Velocity这个.NET平台下的分布式内存缓存系统的过程中,现在让我们将目光暂时投向其他已经有所建树的软件开发商.Al ...

  3. Linq 更改主键值

    有一个班级表,主键是class_id,在管理班级时要进行逻辑删除,而只是单纯的is_del字段(记录每条数据是否有效)更改为true,主键class_id如果不变动,在再次增加一个班级时,其主键如果和 ...

  4. win32多线程-重写消息循环

    最近正在学习<win32多线程程序设计>,这是其中一段重写消息循环的代码事例,以后可能用的上. while (!quit || gNumPrinting > 0) { // Wait ...

  5. 当ArcGIS10.2遇到Teradata

                                    随着计算机技术的不断发展,GIS技术也紧跟IT技术的热潮,从三维技术.到移动技术,从大数据技术到云计算技术,只要IT有的新技术,Esri ...

  6. PHP自学之路---雇员管理系统(2)

    这个章节将讲解分层模式对雇员管理系统的系统,首先看下基本的流程图设计: 下面是具体的代码: 1.login.php(参照上节) 2.loginProcess.php <?php /** * * ...

  7. EasyMock入门

    这是一个JavaProject,有关EasyMock用法详见本文测试用例 首先是用到的实体类User.java package com.jadyer.model; public class User ...

  8. 蓝牙UUID——Android各种蓝牙设备的UUID

    本文转自:http://www.14blog.com/archives/481 UUID是“Universally Unique Identifier”的简称,通用唯一识别码的意思.对于蓝牙设备,每个 ...

  9. 使用MFC CImage类绘制PNG图片时遇到的问题

    为了测试CImage绘制PNG图片的效果,我们用截图软件截得一张360的界面,然后使用PhotoShop等工具在图片的周边加上了透明的区域,然后保存成PNG图片文件.CImage首先从文件中加载,即 ...

  10. 开源 免费 java CMS - FreeCMS1.4-功能说明-站点管理

    下载地址:http://code.google.com/p/freecms/ 站点管理 FreeCMS支持网站群模式,并支持无限树级管理. 1.  添加一级站点 从左侧管理菜单点击站点管理进入. 提示 ...