【软件开发】版本管理Git

志扬工作室

共 3478字,需浏览 7分钟

 ·

2021-07-07 21:05

Start:关注本公众号后,可直接联系后台获取排版美化的详细文档!

Hints:本篇文章所编纂的资料均来自网络,特此感谢参与奉献的有关人员。


  • Git的基本简介:

Git 是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。Git 与常用的版本控制工具 CVS, Subversion 等不同,它采用了分布式版本库的方式,不必服务器端软件支持。

 

  • Git的基本概念:

工作区:就是你在电脑里能看到的目录。

暂存区:英文叫 stage 或index。一般存放在 .git 目录下的index 文件(.git/index)中,所以我们把暂存区有时也叫作索引(index)。

版本库:工作区有一个隐藏目录 .git,这个不算工作区,而是 Git 的版本库。


-图中左侧为工作区,右侧为版本库。在版本库中标记为 "index" 的区域是暂存区(stage/index),标记为 "master" 的是 master 分支所代表的目录树。

-图中我们可以看出此时"HEAD" 实际是指向 master 分支的一个"游标"。所以图示的命令中出现 HEAD 的地方可以用 master 来替换。

-图中的 objects 标识的区域为 Git 的对象库,实际位于 ".git/objects" 目录下,里面包含了创建的各种对象及内容。

-当对工作区修改(或新增)的文件执行 gitadd 命令时,暂存区的目录树被更新,同时工作区修改(或新增)的文件内容被写入到对象库中的一个新的对象中,而该对象的ID被记录在暂存区的文件索引中。

-当执行提交操作(git commit)时,暂存区的目录树写到版本库(对象库)中,master 分支会做相应的更新。即 master 指向的目录树就是提交时暂存区的目录树。

-当执行 git resetHEAD 命令时,暂存区的目录树会被重写,被 master 分支指向的目录树所替换,但是工作区不受影响。

-当执行 git rm--cached <file> 命令时,会直接从暂存区删除文件,工作区则不做出改变。

-当执行 gitcheckout . 或者 git checkout -- <file> 命令时,会用暂存区全部或指定的文件替换工作区的文件。这个操作很危险,会清除工作区中未添加到暂存区中的改动。

-当执行 gitcheckout HEAD . 或者 git checkout HEAD<file> 命令时,会用 HEAD 指向的 master 分支中的全部或者部分文件替换暂存区和以及工作区中的文件。这个命令也是极具危险性的,因为不但会清除工作区中未提交的改动,也会清除暂存区中未提交的改动。

 

  • Git的工作流程:


工作流程如下:

克隆 Git 资源作为工作目录。

在克隆的资源上添加或修改文件。

如果其他人修改了,你可以更新资源。

在提交前查看修改。

提交修改。

在修改完成后,如果发现错误,可以撤回提交并再次修改并提交。


Git的基本操作:

git clone、gitpush、git add 、gitcommit、git checkout、gitpull

-workspace:工作区

-staging area:暂存区/缓存区

-local repository:版本库或本地仓库

-remote repository:远程仓库

创建仓库命令

命令

说明

git init

初始化仓库

git clone

拷贝一份远程仓库,也就是下载一个项目。

提交与修改

Git 的工作就是创建和保存你的项目的快照及与之后的快照进行对比。

下表列出了有关创建与提交你的项目的快照的命令:

命令

说明

git add

添加文件到仓库

git status

查看仓库当前的状态,显示有变更的文件。

git diff

比较文件的不同,即暂存区和工作区的差异。

git commit

提交暂存区到本地仓库。

git reset

回退版本。

git rm

删除工作区文件。

git mv

移动或重命名工作区文件。

提交日志提交日

命令

说明

git log

查看历史提交记录

git blame <file>

以列表形式查看指定文件的历史修改记录

远程操作

命令

说明

git remote

远程仓库操作

git fetch

从远程获取代码库

git pull

下载远程代码并合并

git push

上传远程代码并合并

列出分支基本命令:

git branch

切换分支命令:

git checkout (branchname)

创建新分支并立即切换到该分支下,从而在该分支中操作。

 git checkout -b (branchname)

创建分支命令:

git branch (branchname)

删除分支命令:

git branch -d (branchname)

分支合并

一旦某分支有了独立内容,你终究会希望将它合并回到你的主分支。你可以使用以下命令将任何分支合并到当前分支中去:

git merge

以列表形式查看指定文件的历史修改记录。

git blame <file> 

Git 标签

git tag -a <tagname>

指定标签信息命令

git tag -a <tagname> -m "runoob.com标签"

要查看当前配置有哪些远程仓库,可以用命令:

git remote

从远程仓库下载新分支与数据:

git fetch

推送你的新分支与数据到某个远端仓库命令:

git push [alias] [branch]

删除远程仓库你可以使用命令:

git remote rm [别名]

入要上传的仓库,添加远程地址:

git remote add origin git@github.com:yourName/yourRepo.git

在合并改动之前,你可以使用如下命令预览差异:
git diff <source_branch> <target_branch>

 

  • Git的下载安装:

http://git-scm.com/downloads

 

  • Git的使用示例:

Git的命令桌面:

-查看Git的版本

-查看Git仓库的状态

-查看历史提交记录

-配置本地全局姓名和邮箱

-设置Git默认使用的文本编辑器, 一般可能会是 Vi 或者 Vim。

-设置在解决合并冲突时使用的差异分析工具。比如要改用 vimdiff

-查看配置的信息

-查看环境变量的设定

-Git仓库的初始化

-Git仓库创建目录

-Git 添加文件

-Git提交,进行确定,在Git的记录中保存

-Git克隆,从现有Git仓库中拷贝项目

执行该命令后,会在当前目录下创建一个名为grit的目录,其中包含一个 .git 的目录,用于保存下载下来的所有版本记录。

-Git克隆,从现有Git仓库中拷贝项目至新的目录

执行该命令后,会在当前目录下创建一个名为mygrit的目录,其中包含一个 .git 的目录,用于保存下载下来的所有版本记录。

 

  • 参考资料:

Git的教程:

https://www.runoob.com/manual/github-git-cheat-sheet.pdf

https://www.runoob.com/git/git-tutorial.html

Github 简明教程 | 菜鸟教程(runoob.com)

https://www.runoob.com/w3cnote/git-guide.html

Git的官网:

https://git-scm.com/

Git私有仓库服务器搭建

https://www.runoob.com/git/git-server.html

用git从远程仓库下载代码到本地(非master分支)_每天进步一点点-CSDN博客_git远程下载代码

https://blog.csdn.net/KingJin_CSDN_/article/details/83110900

公众号二维码

End:如果有兴趣了解金融量化交易和其他数据分析的实用技术,欢迎关注本公众号

浏览 34
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报