【软件开发】版本管理Git
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:如果有兴趣了解金融量化交易和其他数据分析的实用技术,欢迎关注本公众号