一、Git简单介绍

Git是眼下世界上最先进的分布式版本号控制系统。其特点简单来说就是:高端大气上档次!

二、Windows上Git安装

最早Git是在Linux上开发的。非常长一段时间内。Git也仅仅能在Linux和Unix系统上跑。只是,慢慢地有人把它移植到了Windows上。如今,Git能够在Linux、Unix、Mac和Windows这几大平台上正常执行了。

msysgit是Windows版的Git,从http://msysgit.github.io/下载。然后按默认选项安装就可以。安装完毕后,在開始菜单里找到“Git”->“Git
Bash”,蹦出一个类似命令行窗体的东西,就说明Git成功安装!

安装完毕后。还须要最后一步设置,在命令行输入:

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

由于Git是分布式版本号控制系统,所以,每一个机器都必须自报家门:你的名字和Email地址。

三、创建版本号库

什么是版本号库呢?版本号库又名仓库,英文名repository。你能够简单理解成一个文件夹,这个文件夹里面的全部文件都能够被Git管理起来,每一个文件的改动、删除,Git都能跟踪。以便不论什么时刻都能够追踪历史。或者在将来某个时刻能够“还原”。

所以,创建一个版本号库很easy。首先,选择一个合适的地方,创建一个空文件夹:

$ mkdir learngit
$ cd learngit
$ pwd
/Users/michael/learngit

pwd命令用于显示当前文件夹。假设你使用Windows系统,为了避免遇到各种莫名其妙的问题,请确保文件夹名(包括父文件夹)不包括中文。

第二步,通过git init命令把这个文件夹变成Git能够管理的仓库:

$ git init
Initialized empty Git repository in /Users/michael/learngit/.git/

这样版本号库就创建好了。

自己主动创建的.git的文件夹。这个文件夹是Git来跟踪管理版本号库的,没事千万不要手动改动这个文件夹里面的文件,不然改乱了,就把Git仓库给破坏了。

第三步,往版本号库加入文件:全部的版本号控制系统,其实仅仅能跟踪文本文件的修改。比方TXT文件,网页。全部的程序代码等等,Git也不例外。其实使用windows的童鞋千万不要使用Windows自带的记事本编辑不论什么文本文件。

建议你下载Notepad++取代记事本。

<span style="color:#000000;">//假如在当前文件夹创建了一个read.txt文件

$git add read.txt; //把文件加入到仓库

$git commit -m "wrote a readme file"  //把文件提交到仓库,-m后面输入的是本次提交的说明,能够输入随意内容</span>

四、经常使用命令:

除了git add 和 git commit,其它经常使用命令例如以下:

1、git status:查看仓库当前的状态

2、git diff file:查看文件详细改动的内容,file是文件名称

3、git log:显示从近期到最远的提交日志

4、cat read.txt:查看文件内容

5、git reflog:查看你使用的命令历史

6、git checkout -- read.txt:撤销对read.txt的全部改动,不要丢掉了--

7、git reset --hard id/^HEAD:回退版本号,id是版本号号。^HEAD是指向最新版本号的指针

8、git rm read.txt:删除read.txt文件,记住要用commit提交才干真正从仓库删除。假设误删。能够用git checkout命令撤销

9、git remote add origin git@github.com:dwqs/csdn.git:将本地仓库和Github上的远程仓库关联,记得将dwqs换成你自己的账户名,csdn.git是你在GitHub上创建的仓库

10、git push -u origin master:把本地库的全部内容推送到远程库上,第一次提交加上-u,第二次提交能够不用了:git push origin master

11、git clone git@github.com:dwqs/csdn.git:把远程仓库csdn.git克隆到本地

12、git checkout -b name:创建name分支。该命令等价于:git branch name;git checkout name

13、git branch:查看当前分支

14、git checkout name:切换到name分支

15、git merge name:合并某分支到当前分支

16、git branch -d name:删除name分支

17、git branch -D name:强行删除name分支

18、git push origin name:将name分支推送到远程仓库

19、git remote -v:查看远程仓库信息

20、git tag:查看标签名

21、git tag tagname:创建标签

22、git show tagname:查看标签信息。

注意:标签不是按时间顺序列出,而是按字母排序的。

23、git tag -a tagname -m tagdesc:创建带说明的标签

24、git tag -d tagname:删除指定标签

25、git push origin tagname:推送某个标签到远程仓库

26、git push origin --tags:一次性推送所有尚未推送到远程的本地标签

27、git push origin :refs/tags/tagname:能够删除一个远程标签。

28、git config --global alias.ps push:将ps作为push的别名。此时,git ps 等价于git push


Git学习笔记总结和注意事项的更多相关文章

  1. Git学习笔记与IntelliJ IDEA整合

    Git学习笔记与IntelliJ IDEA整合 一.Git学习笔记(基于Github) 1.安装和配置Git 下载地址:http://git-scm.com/downloads Git简要使用说明:h ...

  2. Git学习笔记(10)——搭建Git服务器

    本文主要记录了Git服务器的搭建,以及一些其他的配置,和最后的小总结. Git远程仓库服务器 其实远程仓库和本地仓库没啥不同,远程仓库只是每天24小时开机为大家服务,所以叫做服务器.我们完全可以把自己 ...

  3. Git学习笔记(四)

    一.忽略特殊文件 在Git工作区的根目录下创建一个特殊的.gitignore文件,然后把要忽略的文件名填进去,Git就会自动忽略这些文件. 不需要从头写.gitignore文件,GitHub已经为我们 ...

  4. git 学习笔记6--remote & log

    git 学习笔记6--remote & log 创建SSH Keys ssh-keygen -t rsa -C "1050244110@qq.com" 本地关联远程 git ...

  5. Git学习笔记---协作的一般流程

    一般的操作流程 1.pull 王小坤与另一个同事张大炮一起开发一个项目,张大炮昨天修改了数据库读写的api,优化了执行速度,并把read()函数改名成了Read(),下午下班之前把这些代码push到服 ...

  6. 【转帖】Git学习笔记 记录一下

    本文内容参考了廖雪峰老师的博文,并做了适当整理,方便大家查阅. 原帖地址 https://wangfanggang.com/Git/git/ 常用命令 仓库初始化 - git init 1 git i ...

  7. [转]Git学习笔记与IntelliJ IDEA整合

    Git学习笔记与IntelliJ IDEA整合 一.Git学习笔记(基于Github) 1.安装和配置Git 下载地址:http://git-scm.com/downloads Git简要使用说明:h ...

  8. GIT学习笔记(1):创建版本库

    GIT学习笔记(1):创建版本库 创建版本库 1.创建合适目录并初始化为仓库 版本库即需要交由Git进行版本控制的目录,其下所有文件的修改.删除,Git都能跟踪还原. 说明:初始化后,当前目录下会多出 ...

  9. GIT学习笔记(5):变基

    GIT学习笔记(5):变基rebase 变基 引入变基 在Git中整合来自不同分支的修改主要有两种方法:merge以及rebase. 整合分支最容易的方法是merge,他会把两个分支的最新快照以及两者 ...

随机推荐

  1. 分区 Service Bus 队列和主题

    编辑人员注释:本文章由 Windows Azure Service Bus 团队的二级项目经理 Ruppert Koch 撰写. 上周,Microsoft 发布了 Azure SDK 2.2 和 Se ...

  2. 【蓝桥杯】入门训练 Fibonacci数列

      入门训练 Fibonacci数列   时间限制:1.0s   内存限制:256.0MB        问题描述 Fibonacci数列的递推公式为:Fn=Fn-1+Fn-2,其中F1=F2=1. ...

  3. 搞不清FastCgi与PHP-fpm之间是个什么样的关系 - SegmentFault

    搞不清FastCgi与PHP-fpm之间是个什么样的关系 - SegmentFault 搞不清FastCgi与PHP-fpm之间是个什么样的关系 3赞 踩 收藏 我在网上查fastcgi与php-fp ...

  4. HDU 4859(Bestcoder #1 1003)海岸线(网络流之最小割)

    题目地址:HDU4859 做了做杭电多校,知识点会的太少了.还是将重点放在刷专题补知识点上吧,明年的多校才是重点. 这题题目求的最长周长.能够试想一下,这里的海岸线一定是在"."和 ...

  5. 碰撞缓冲效果的导航条 js

  6. 解决:Visual Assist X 不支持HTML、Javascript等提示

    Visual Assist X 安装后,不能进行javascript hmtl提示,只有回到老版本才行.这个问题折腾了老久,才给解决了. 记录下来,以便于网友和自己使用. 问题原因: Visual A ...

  7. [译]Stairway to Integration Services Level 15 – SSIS 参数回顾

    介绍 在本文中我们会研究SSIS变量姐妹: SSIS 变量. 我们会演示参数配置,通过包参数管理动态属性值,然后会演示SSIS包执行的时候参数怎么被配置的. SSIS Parameters 101 S ...

  8. SDWebImage内部实现过程

    入口 setImageWithURL:placeholderImage:options: 会先把 placeholderImage 显示,然后 SDWebImageManager 根据 URL 开始处 ...

  9. FreeCodeCamp:Title Case a Sentence

    要求: 确保字符串的每个单词首字母都大写,其余部分小写. 像'the'和'of'这样的连接符同理. 结果: titleCase("I'm a little tea pot") 应该 ...

  10. JavaScript 导学推荐

    基本开始js学习的时候,可能会觉得很混乱,一开始都是从一些简单的表单验证还有拷贝别人效果代码,然后再慢慢去深入了解.我是觉得js是需要一定语言编程基础,我是觉得随着深入,JS的里面实在不算太好理解,个 ...