git的简单理解及基础操作命令

前端小白一枚,最近开始使用git,于是花了2天看了廖雪峰的git教程(偏实践,对于学习git的基础操作很有帮助哦),也在看《git版本控制管理》这本书(偏理论,内容完善,很不错),针对所学内容建了git仓库测试,且写了不少git操作命令的笔记,做个分享,有错误的地方各位大大也给提出,好做修改~

Git是一款免费、开源的、用Linux内核开发的分布式版本控制系统。

git和svn有什么区别呢?

git采用分布式版本库管理,而svn采用集中式版本库管理。

集中式版本库管理需要有一台存放版本库的服务器,开发人员在开发的时候分别从服务器拉取过来最新版本,然后创建/进入分支进行开发,开发完成之后将分支提交或者合并到主分支。

分布式版本库管理允许开发者们将版本库搬到自己的电脑上,在开发过程中,开发者们可以根据不同的目的创建分支和修改代码,开发完成后进行各项合并,这样做提高了开发的敏捷性和速度,并且减少了公共服务器的压力,且任意两个开发者之间的冲突更容易得到解决。

git安装

首先,你可以在你的电脑上执行"git"命令,检查是否已安装git。如果已安装,则会列出它的选项和最常用的子命令。如果未安装,则打印提示未安装或不是内部/外部命令。

安装包下载地址:git.download,按需选择吧,想必凭各位多年的电脑开关机经验,QQ、浏览器、游戏等的安装卸载经验,这步骤应该不会出现什么问题。

git的配置

安装完git,我们执行"git"命令查看它的选项和最常用的子命令。
//这里命令也就不一一列出了,大家自己执行看下即可(让我伪装下注释,谢谢~)

然后就是配置你的名称及邮箱:

git config --global user.name "yeshou"
git config --global user.email "xxx@qq.com"

我们可以通过根目录下的.gitconfig文件查看配置信息,这里加了--global,所以是全局配置,若其他仓库木有单独配置,则使用的是全局的,如果其他仓库需要单独配置,去掉--global重复以上操作即可,同理,可在对应仓库文件夹下看.gitconfig文件的配置信息(友情提示,这是个隐藏文件)。

生成SSH-key

配置完了git的提交人信息,我们在本地生成个ssh-key,用来验证提交者身份。

ssh-keygen -t rsa -C "xxx@qq.com"

然后在.ssh文件夹下找到id_rsa.pub文件,里面内容复制到github的"setting"下的"SSH and GPG keys"的添加过程的输入框里,用以生成ssh-key。

在github上实践

在github上创建一个远程仓库,登录github网站,通过右上角"New respository"新建一个比如名为"git-test"的项目仓库。我们打开项目仓库的首页,复制仓库地址(既然配置了SSH,那就选择SSH咯;当然,也可以通过HTTP的来clone),可以通过git clone 命令将远程仓库拉到本地。

git clone "git@github.com:your-github-name/git-test.git"

这样就把项目拉取到当前文件夹下了,so easy~       之后,我们可以操作本地文件夹进行增删改查等操作,下面列出一些操作。

在操作之前,需要了解工作区和暂存区和版本库的概念。

工作区:电脑中的文件夹内容

版本库:工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD。

暂存区:该内容存在于隐藏的.git目录下,可以简单理解为,需要提交的文件修改通通放到暂存区,然后一次性提交暂存区的所有修改。

详情点击此链接,有图有真相啊~

git基础操作命令

文件操作

将文件添加到版本库

git add TEST.md  //添加了一个TEST.md文件

将版本库中文件重命名

git mv TEST.md LALALA.md  //改名:TEST => LALALA

将文件从版本库删除

git rm LALALA.md  // 删除LALAL.md 文件

查看操作记录

git log  //如果觉得信息太多,可以加参数"--pretty=oneline",这样就能够输出简短信息。

列出master分支的历史操作

git log master 

列出某个文件的历史操作

git log LALALA.md

然后在上一句操作中你会发现,追溯LALALA文件的操作历史的时候看不到它改名之前的历史,怎么办呢?

git log --follow LALALA.md  //加上"--follow"参数会让git在日志中内容相关联的整个历史记录

查看你的每一次操作命令

git reflog  //列出每次你的操作命令,如:log、add、rm等

版本回退

git reset --hard HEAD^  //HEAD表示当前版本,加^表示上一个,加^^表示上上个...
git reset --hard commit-id  //我们可以通过git log拿到指定版本的提交id,并且返回到指定版本

查看工作区状态

git status  //可看出是否对文件进行修改

将修改提交到暂存区

git add fileName //添加修改的文件
git commit -m "message" //提交修改的文件,并且输入修改信息

将暂存区的文件提交到远程仓库

git push (master)  //不填则默认提交到当前分支,也可提交到指定分支

查看工作区与版本库中最新版本之间的不同

git diff HEAD fileName  //当文件在工作区修改后还未提交到版本库

丢弃在工作区所做的修改

git checkout -- index.html   //丢弃对index.html的修改

将远程仓库的修改拉取到本地

git fetch (master)  //不填则默认拉取当前分支的最新修改,也可指定需要拉取的分支,fetch之后并不会合并修改
git pull (master)  //不填则默认拉取当前分支的最新修改,也可指定需要拉取的分支,pull之后合并修改

分支操作

分支是在软件项目中启动一条单独的开发线的基本方法,使得开发能够在多个方向上同时进行,分支一般会被调解并与其他分支合并,用来合并不同的开发。通俗来讲,相当于将一个大任务分解成多个小任务,分给多人同时进行处理,完了再组合到一起,于是完成了个大任务。

创建分支

git branch dev  //创建了一个dev分支,然而并没切换到这个分支上

切换分支

git checkout dev  //切换到dev分支上

创建并且切换分支

git checkout -b dev  //创建了一个dev分支,并且切换到这个分支上

打了一遍上面的命令,然后屁颠屁颠跑去github刷新看分支,然而并没有,少年莫慌,那是因为你还没将分支提交到远程仓库~

将分支放到远程仓库

git push origin dev  //好了,将dev分支提交到远程仓库了,然后又跑去刷新了github,这次终于看到分支的存在了

查看分支

git branch  //带星号的是当前分支,加参数"-r"查看远程分钟,"-a"查看所有分支

合并分支
注:首先明确目前在哪个分支上,不可以在当前分支上将此分支合并到其他分支。

git merge dev  //假如我现在在master分支上,然后合并了dev分支

通常合并分支的时候,git使用Fast-forward模式,我们可以在合并的时候使用参数"--no-ff"禁用该模式

git merge --no-ff -m "" dev  //这样的合并会创建一个新的commit

这时分支合并了,然后你会发现分支依然存在,怎么办呢?
删除分支

git branch -d dev  //删除dev分支
git branch -D dev  //强制删除dev分支

这时候问题又来了,去github刷新看dev分支还是存在的...
删除远程分支

git push origin --delete dev  //删除了远程仓库中的dev分支

删除不存在对应本地分支的远程分支

git remote prune origin

删除不存在对应远程分支的本地分支

git fetch -p 

查看分支合并流程图

git log --graph //明确的看到何时创建/修改/合并分支

标签操作

标签可以简单的看做是一个标识点或者参考点。它是个静态的名字,不随时间的推移而改变。而分支是动态的,且随着你每次的提交而移动。他们之间看起来相似,但我们需要分清楚他们,且勿将其混淆。

创建一个标签

git tag v0.1  // 创建一个标签,名为v0.1=> version 0.1

将标签推到远程仓库

git push origin v0.1

一次性推送所有标签

git push origin --tags

删除本地标签

git tag -d v0.1  //删除名为v0.1的标签

删除远程仓库的标签

git push origin :refs/tags/v0.1

进度暂存操作(类似游戏的存档)

git提供一个"存档"功能。比如,当你正在改一个功能的时候,临时需要修改另一个功能,而且比较重要,而又不能直接checkout丢弃当前的修改,这时候git提供的"存档"就好用了。可以将之前的修改暂时存起来,把工作区恢复到干净的环境供你修改另一个功能。

创建一个"存档"

git stash  //暂时存储了当前的操作进度

查看"存档"的列表

git stash list

查看"存档"内容

git stash show stash@{index} //查看相对索引的存档内容,不加stash@{index}则默认是最近的"存档"

恢复"存档"

git stash apply stash@{index} //恢复相对索引的存档内容,不加stash@{index}则默认是最近的"存档"

恢复之后会发现,这个"存档"还在存档列表中,简直跟玩rpg游戏一样么~
删除"存档"

git stash drop stash@{index} //删除相对索引的存档内容,不加stash@{index}则默认是最近的"存档"

清除所有"存档"

git stash clear //毕竟一个个drop太累

给命令配置别名

如果你嫌一些命令麻烦或者太长或者不好记等等...

git config --global alias.cmt commit

然后你就可以使用"git cmt"代替"git commit"了。

删除别名

打开.gitconfig文件,找到[alias]的内容,删除对应别名的行内容即可

.gitignore文件

可以在文件夹下添加.gitignore文件,告诉git在执行命令的时候忽略一些内容。

具体操作:打开.gitignore,在后面一行添加需要忽略的内容。

文件夹: 如"src/" //忽略src文件夹下的所有文件

文件:如"*.jpg" //忽略以jpg为后缀的文件

...

向git求助

git help  //列出参数列表及命令列表
git help command  //打开该命令的html文档
git command --help  //打开该命令的html文档

暂时就这么多吧~还在继续学习更多git用法,之后整理出来的笔记如果可以的话也会分享哦~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/398358.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

iOS 后台挂起的一些坑

特别说明:后台状态:当前app如果不是作为屏幕中的第一层,呈现显示给用户,那么此时app就是后台状态。锁屏(包括:当前应用下锁屏、其他应用下锁屏、桌面锁屏) 用户在使用其他应用app2,…

OSGI 生命周期

1 生命周期管理 对于非模块化应用,生命周期将应用作为一个整体来操作;而对于模块化应用,则可以以细粒度的方式来管理应用的某一个独立部分。OSGi生命周期管理 OSGi生命周期层有两种不同的作用: 在应用程序外部,定义了对…

tomcat+nginx+redis实现均衡负载、session共享

在项目运营时,我们都会遇到一个问题,项目需要更新时,我们可能需先暂时关闭下服务器来更新。但这可能会出现一些状况:1.用户还在操作,被强迫终止了(我们可以看日志等没人操作的时候更新,但总可能会有万一)2.不知道的用户…

洛谷 P3184 [USACO16DEC]Counting Haybales数草垛

洛谷 P3184 [USACO16DEC]Counting Haybales数草垛 题目描述 Farmer John has just arranged his NN haybales (1 \leq N \leq 100,0001≤N≤100,000 ) at various points along the one-dimensional road running across his farm. To make sure they are spaced out appropria…

关于笔试的一些博客

这里收集了一些阿里的网上笔试题目 阿里笔试题(2015)持续更新中腾讯阿里实习生招聘笔试总结阿里2014研发实习生笔试题解析【阿里】算法工程师笔试题整理(13&14年)【阿里】算法工程师笔试【2015.04.02】转载于:https://www.cnblogs.com/chen310/p/438…

Entity Framework 6 Recipes 2nd Edition(13-2)译 - 用实体键获取一个单独的实体

问题 不管你用DBFirst,ModelFirst或是CodeFirst的方式,你想用实体键获取一个单独的实体.在本例中,我们用CodeFirst的方式. 解决方案 假设你有一个模型表示一个Painting(绘画)类型的实体,如Figure 13-2所示: Figure 13-2. The Painting entity type in our model 在代码In Listi…

C#心得与经验(二)

本周学到很多C#关于Interface, Array的知识&#xff0c;在这里简单复习一下几个易混的地方&#xff0c;重在理解。 一、Interface 使用as来避免多态时没有接口的Exception&#xff1a; Document [] folder new Document[5]; for (int i 0; i < 5; i) {if (i % 2 0){fold…

java实例化对象

摘要&#xff1a;分享牛&#xff0c;分享牛分享&#xff0c;java类加载机制&#xff0c;java实例化对象&#xff0c;java实例化对象机制&#xff0c;java基础。 java是如何实例化对象的呢&#xff1f;以及实例化对象的先后顺序是什么&#xff1f;下面我们以测试的方式说明. 1.1…

项目总结(3.28)

项目是用vuewebpackelementUI 完成的。虽然没有什么深奥的技术和难点&#xff0c;但是有些细节还是值得注意的。 1、满足不同屏幕尺寸下缩放全屏显示。 单单只靠宽度、高度百分比是不可以实现的&#xff0c;比如如果宽度设置百分比&#xff0c;当屏幕宽度比较小时&#xff0c;这…

Android开发删除短信

本人一直有一个需求&#xff0c;想要手机自动拦截黑名单里联系人的信息并自动删除这些短信&#xff0c;手机管家之类的软件可以拦截但是没找到能删除这些短信的&#xff0c;于是就萌生了想自己写一个android软件的想法。 加上物联网的兴起&#xff0c;安卓设备开发肯定前景很好…

让你提升命令行效率的 Bash 快捷键 [完整版]

生活在 Bash shell 中&#xff0c;熟记以下快捷键&#xff0c;将极大的提高你的命令行操作效率。 编辑命令 Ctrl a &#xff1a;移到命令行首Ctrl e &#xff1a;移到命令行尾Ctrl f &#xff1a;按字符前移&#xff08;右向&#xff09;Ctrl b &#xff1a;按字符后移&…

Okhttp的封装和回调

public class HttpUtil {static HttpUtil util;private final OkHttpClient client;// 私有化构造方法private HttpUtil(){client new OkHttpClient();}public static HttpUtil getInstance(){if(util null){synchronized (HttpUtil.class){util new HttpUtil();}}return u…

将Session写入Memcache

通过session_set_save_handler()方法自定义Session写入Memcache 1 <?php 2 class MemSession{3 private static $handler null;4 private static $lifetime null;5 private static $time null;6 const MS session;7 8 …

微软解决方案全景

我遇到过一家企业的CTO&#xff0c;做过很多知名大企业的信息化规划设计&#xff0c;但他基本是一个Like Unix派系的技术&#xff0c;而我是一个Microsoft派系的技术&#xff0c;在这里我不是讨论哪个派系的技术好和不好&#xff0c;我只是在和他的聊天中发现了一些非常有意思的…

Going Dutch BAPC( 状态转移DP)

题目描述 You and your friends have just returned from a beautiful vacation in the mountains of the Netherlands. When on vacation, it’s annoying to split the bill on every expense every time, so you just kept all the receipts from the vacation, and wrote d…

查询指定目录下的文件中是否包含指定字符串

cd /etc/apache2/site-enable/rep -rl test.com ./*意为查询apache虚拟主机中是否包含test.com的域名转载于:https://blog.51cto.com/linuxtips/1773938

使用 C# 编程对RTF文档的支持

http://www.68design.net/Development/Aspnet/Basis-AspNet/26011-1.html 转载于:https://www.cnblogs.com/faxian/p/4402910.html

algorand共识协议_【Filecoin】理解预期共识 - 及它的优缺点

摘 要预期共识就是上帝掷飞镖预期共识的优点在于简单&#xff0c;而且每一次选举胜出者数量的平均数为1但预期共识不能保证每次选举的胜出者数量&#xff0c;这是其最大的问题期待有更好的基于可验证随机函数的共识算法出现&#xff0c;设计者可获得20万美金奖赏预期共识 就是 …

Android软件安全与逆向分析之Dalvik

注意点 首先&#xff0c;让我们来思考下面几个问题&#xff1a; 什么是Dalvik虚拟机? Dalvik VM与JVM有什么区别&#xff1f; Dalvik VM有什么新的特点&#xff1f; Dalvik VM的架构是怎么样的&#xff1f; 首先&#xff0c;我得承认第一个问题问得很傻&#xff1a;什么是Dalv…

在java中实现日期类型和字符串类型的转换大全(Date String Timestamp Datetime)

用Timestamp来记录日期时间还是很方便的&#xff0c;但有时候显示的时候是不需要小数位后面的毫秒的&#xff0c;这样就需要在转换为String时重新定义格式。 Date、String、Timestamp之间的转换&#xff01; [java] view plaincopyprint? public static void main(String[] ar…