git入门使用(代码片段)

阿轩的BLOG 阿轩的BLOG     2022-10-27     374

关键词:

Git是什么?

 

Git是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。

Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。

关于Git的诞生,这里还有一个小故事。

Linus在1991年创建了开源的Linux,从此,Linux系统不断发展,已经成为最大的服务器系统软件了。
Linus虽然创建了Linux,但Linux的壮大是靠全世界热心的志愿者参与的,这么多人在世界各地为Linux编写代码,那Linux的代码是如何管理的呢?
事实是,在2002年以前,世界各地的志愿者把源代码文件通过diff的方式发给Linus,然后由Linus本人通过手工方式合并代码!
你也许会想,为什么Linus不把Linux代码放到版本控制系统里呢?不是有CVS、SVN这些免费的版本控制系统吗?因为Linus坚定地反对CVS和SVN,这些集中式的版本控制系统不但速度慢,而且必须联网才能使用。有一些商用的版本控制系统,虽然比CVS、SVN好用,但那是付费的,和Linux的开源精神不符。
不过,到了2002年,Linux系统已经发展了十年了,代码库之大让Linus很难继续通过手工方式管理了,社区的弟兄们也对这种方式表达了强烈不满,于是Linus选择了一个商业的版本控制系统BitKeeper,BitKeeper的东家BitMover公司出于人道主义精神,授权Linux社区免费使用这个版本控制系统。
安定团结的大好局面在2005年就被打破了,原因是Linux社区牛人聚集,不免沾染了一些梁山好汉的江湖习气。开发Samba的Andrew试图破解BitKeeper的协议(这么干的其实也不只他一个),被BitMover公司发现了(监控工作做得不错!),于是BitMover公司怒了,要收回Linux社区的免费使用权。
Linus可以向BitMover公司道个歉,保证以后严格管教弟兄们,嗯,这是不可能的。实际情况是这样的:
Linus花了两周时间自己用C写了一个分布式版本控制系统,这就是Git!一个月之内,Linux系统的源码已经由Git管理了!牛是怎么定义的呢?大家可以体会一下。

 

安装Git

 

vs2017安装时可以勾选Git。

小伙伴们也可以去官网: https://git-scm.com/downloads

一般来说,git配合小乌龟使用 https://tortoisegit.org/download/ 根据自己的处理器位数选择对应的就好了,还有中文语言包。

要先安装小乌龟,再安装语言包,安装后需要在小乌龟里设置语言才能使用。

 

 

简单命令

 

设置全局用户名和通讯地址:

$ git config --global user.name "Your Name"
$ git config --global user.email "[email protected]"

 

创建版本库:

在 Windows 上,我们只需要鼠标右键,选择·Git Bash Here 就可以了

这样打开 git 控制台,路径就会已经被设定到当前你点击的目录了。

当然也可以使用下面的语句来切换目录。这条语句将目录切到了C盘根目录。

$ cd C:/

然后接下来 通过git init命令把这个目录变成Git可以管理的仓库:

$ git init

可以发现当前目录下多了一个 .git 的目录,这个目录是 Git 来跟踪管理版本库的,没事千万不要手动修改这个目录里面的文件,不然改乱了,就把Git仓库给破坏了。

如果你没有看到 .git 目录,那是因为这个目录默认是隐藏的

 

把文件添加到版本库:

使用 $ git add 命令 + 文件名的方式,往仓库里添加一个文件。

$ git add xxx.txt

还有一个命令是添加目录下所有的文件到仓库。

$ git add .

 

创建一个提交:

用命令 $ git commit告诉Git,把文件提交到仓库:

$ git commit -m "test git"

-m 后面的字符串用来说明本次提交的备注信息。建议严肃对待这个备注,避免以后自己想要找回版本,却想不起自己哪次提交做了改动。

 

查看仓库当前状态:

运行 $ git status 命令看看结果:

$ git status

使用 $ git log 命令可以查看显示从最近到最远的提交日志

$ git log

 

回退版本:

首先,想要往回走的话,必须知道现在自己在哪(废话),

在Git中,用 HEAD 表示当前版本,上一个版本就是 HEAD^,上上一个版本就是 HEAD^^,当然往上100个版本写100个 ^ 比较容易数不过来,所以写成 HEAD~100

使用下面的语句来返回上一个版本

$ git reset --hard HEAD^

那么问题来了,如果我们这个时候又想回去怎么办呢?办法总是有的。

使用下面这个语句我们就可以去到任何一个版本。

$ git reset --hard [版本ID号]

那么,如何才能知道版本号呢?

$ git reflog

$ git reflog用来记录你的每一次命令:

Git的版本回退速度非常快,因为Git在内部有个指向当前版本的HEAD指针,当你回退版本的时候,Git仅仅是把HEAD从指向了那个版本。

 

到这里,git的常用基本命令就这么多。但一般来说。我们使用 git 都是有场景的,那就是远程仓库。

一般来说。我们需要从远程克隆版本库到本地。

克隆版本库:

$ git clone 

克隆下来之后,当然也是你本地的仓库关联的就是远程仓库的地址。

把本地库的内容推送到远程,用git push命令,实际上是把当前分支master推送到远程。

我们第一次推送master分支时,加上了-u参数,-u的意思是将它设置为默认主机,

Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令。

$ git push -u origin master

此后,每次本地提交后,就可以使用命令git push origin master推送最新修改:

$ git push origin master

关于 push https://www.yiibai.com/git/git_push.html这里更加详细的介绍。

我日常都是使用命令行克隆到本地,但提交一般使用小乌龟,或者VS的Git工具。

应当善用工具,站在巨人的肩膀上。对于我们写.NET的来说,不更应该如此吗。

玩转git入门篇(代码片段)

最近项目使用到Git管理项目,所以就学习了一番,随然网上关于Git的文章铺天盖地,我还是整理下总结下自己学习Git相关笔记,希望也能帮助到需要他的小伙伴们,O(∩_∩)O~简介Git是分布式版本控制和源代码管理系统,重点使用... 查看详情

git-入门到熟悉_日志管理(代码片段)

文章目录Pre常用命令演示PreGit-入门到熟悉_Git基本概念与核心命令Git-入门到熟悉_分支管理Git-入门到熟悉_远程仓库管理在使用Git提交了若干更新之后,又或者克隆了某个项目,想回顾下提交历史,可以使用gitlog命令查... 查看详情

git-入门到熟悉_日志管理(代码片段)

文章目录Pre常用命令演示PreGit-入门到熟悉_Git基本概念与核心命令Git-入门到熟悉_分支管理Git-入门到熟悉_远程仓库管理在使用Git提交了若干更新之后,又或者克隆了某个项目,想回顾下提交历史,可以使用gitlog命令查... 查看详情

git快速入门(代码片段)

前篇文章玩转Git入门篇我们已经对Git有了一个大概的了解,接下来我们学习下Git的如何管理项目的。远程仓库Repository(仓库)包含的内容-Git的目标是管理一个工程,或者说是一些文件的集合,以跟踪它们的变化。Git使用Repository来... 查看详情

git入门(代码片段)

1.初始化git,会在home下生成.gitconfig文件。gitconfig--globaluser.namexxxgitconfig--globaluser.email[email protected]2.不使用--global参数时在某项目顶层目录下生成私有配置config,报告单独的名字和邮箱xxx项目目录/.git/config3.需要一个项目的仓... 查看详情

git入门(代码片段)

git初始化设置你的名字和email,这些是你再提交commit时的签名,每次提交记录中都会包含这些信息。使用gitconfig命令进行配置:gitconfig--globaluser.name‘haohj‘gitconfig--globaluser.email‘[email protected]‘执行了上面的命令后,就会在C:... 查看详情

git到github的使用入门(代码片段)

1、使用GitHub基本概念(一)目的借助github托管项目代码仓库(Repository)仓库的意思,即你的项目,你想在GitHub上开源一个项目,那就必须要新建一个Repository,如果你开源的项目多了,你就拥有了多个Repos... 查看详情

git入门到放弃(代码片段)

git基础入门Git是一款免费、开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。Git是LinusTorvalds为了帮助管理Linux内核开发而开发的一个开放源码的版本控制软件。git的安装下载地址注意:不要安装在中文目录... 查看详情

git-入门到熟悉_git基本概念与核心命令(代码片段)

文章目录Git概述GitvsSVN存储方式使用方式管理模式Git核心命令1.GIT客户端安装配置2.GIT的基本使用2.1git项目创建等操作常用命令列表本地添加/删除本地提交gitadd到localcachegitcommit到localrepositorygitpush到remotegitrepository2.2git项目的克隆2.... 查看详情

git入门简介(代码片段)

Git简介:    介绍Git之前,先简单介绍一下版本控制系统。版本控制系统的产生是为了方便多用户对工程及项目的编写、改动的协同系统。版本控制系统分为集中式和分布式。在Git出现之前,版本控制系统是CVS、SVN操作系统... 查看详情

git和码云的使用(代码片段)

什么是码云快速入门 Git入门码云是开源中国社区2013年推出的基于Git的完全免费的代码托管服务,这个服务是基于Gitlab开源软件所开发的,我们在Gitlab的基础上做了大量的改进和定制开发,目前已经成为国内最大的代码托管... 查看详情

(办公)git入门(代码片段)

     git版本库(分布式版本控制系统),可以记录每次文件的改动,是程序开发的好帮手.    1.创建版本库:     repository,你可以简单理解成一个目录,这个目录里面的所有文件都可以... 查看详情

git入门与基本使用(代码片段)

11、分离头指针情况下的注意事项 所谓分离头指针,即在git切换到某一commit时,没有绑定在分支或者tag上,此时如果在该commit下进行了文件修改,并且提交commit时,git在日后清理该提交而不保存,因此在进行commit查看时,最... 查看详情

git-入门到熟悉_分支管理(代码片段)

...;创建一个新分支删除分支gitbranch-d切换分支gitcheckoutPreGit-入门到熟悉_Git基本概念与核心命令接下来,我们聊一聊Git的分支管理使用分支意味着可以从 查看详情

git-入门到熟悉_分支管理(代码片段)

...;创建一个新分支删除分支gitbranch-d切换分支gitcheckoutPreGit-入门到熟悉_Git基本概念与核心命令接下来,我们聊一聊Git的分支管理使用分支意味着可以从 查看详情

atom编辑器入门到精通git支持(代码片段)

原创时间:2016-04-10更新时间:2016-06-05版本控制对于开发来说非常重要,Atom当然也提供了很好的支持,本文将介绍如何在Atom中集成使用Git和GitHub恢复文件当你修改了某个文件,然后发现改得不满意,希望恢复文件到最后一次提交的状态,... 查看详情

简易的命令行入门教程:(代码片段)

Git全局设置:gitconfig--globaluser.name"**"gitconfig--globaluser.email"**@163.com"创建git仓库:mkdir**--democd**--demogitinittouchREADME.mdgitaddREADME.mdgitadd.gitcommit-m"firstcommit"gitcommit#gitremoteaddorigin**********gitpush-uoriginmaster已有仓库?cdexist... 查看详情

git入门手册大全(代码片段)

快速入门GitHubGitHub在程序开发领域家喻户晓,现在几乎整个互联网的开发者都将版本管理工具GitHub作为版本控制的首选,甚至像笔者这样非开发者,一名和每天和数据打交道的人也在使用GitHub,目的主要有:... 查看详情