本篇文章中给大家带来了关于Git版本管理的相关知识,版本管理工具能够纪录每次的修改,只要提交到版本仓库,就可以找到之前任何时刻的状态,希望对大家有帮助。
Git是一个“分布式版本管理工具”。
版本管理工具能够纪录每次的修改,只要提交到版本仓库,就可以找到之前任何时刻的状态。
我们在写东西的时候都用过撤消这个功能,但是撤消只能回撤有限步,通常关闭编辑软件后再重新打开,此时的撤销纪录都已被清空了。而“版本管理工具”则不同,它能记录每次的修改,只要提交到版本仓库,就可以找到之前任何时刻的状态。
创建仓库
安装git软件后,在任意目录下创建一个新文件夹,打开,然后执行git init来创建新的git仓库(该命令将创建一个名为.git的隐藏子目录)。
检出仓库
执行命令git clone + 远程项目地址,用来克隆远端服务器上的仓库。
Git状态
Git有三种状态,分别是已提交(committed)、已修改(modified)、已暂存(staged)。
- 已修改(modified):已修改表示修改了文件,但还没保存到数据库中。
- 已暂存(staged):表示对一个已修改文件的当前版本做了标记,使之包含在下次提交的快照中。
- 已提交(committed):数据已经安全的保存在本地数据库中。
Git的三种状态分别对应本地仓库的三个工作流,本低仓库是由git维护的三棵树组成。
- 第一个是工作目录,持有实际文件,增删文件和内容;
- 第二个是暂存区(Index),像个缓存区域,临时保存改动。输入git add+filename,此次改动就放到了暂存区。
- 第三个是HEAD,指向最后一次提交的结果。输入git commit命令,此次改动就放到了本地仓库。commit之后的可以称为一个版本。
git基本工作流程:
- 提出更改(添加到暂存区)
使用命令git add (针对特定文件)或git add *(针对所有文件)可以提出更改(把它们添加到暂存区)。 - 提交改动
使用命令git commit -m “代码提交信息” 来实际提交改动,执行完后改动就提交到了HEAD,但是还没到远端仓库。 - 推送改动
使用命令git push origin master 将改动提交到远端仓库master分支(通常不会直接提交到master分支,而是推送到自己的分支,核对无误后再进行merge)。
分支
前面提到了master分支,那么如何直观的了解分支呢?
分支是用来将特性开发绝缘开来的。在创建仓库的时候,master是“默认”分支。在其他分支上进行开发,完成后再将它们合并到主分支上。
git branch test1 | 创建一个名字为test1的分支。 |
---|---|
git checkout test1 | 切换当前分支到test1 |
git checkout -b test1 | 创建一个叫做“test1”的分支,并切换过去。 |
git checkout master | 切换回主分支。 |
git branch -d test1 | 把新建的分支删掉。 |
git push origin | 将分支推送到远端仓库。 |
git merge test | 合并分支。 |
更新与合并
使用命令git pull “远程分支名” 从远程获取代码并合并到本低的版本(在工作目录中获取(fetch)并合并(merge)远端的改动)
使用命令git merge “分支名” 把合并其他分支到当前分支。
前面的两种情况,git都会尝试去自动合并改动。但合并可能会出现冲突(conflicts),需要手动修改文件来合并这些冲突。改动后执行git add 将它们标记为合并成功。在合并改动之前,可以使用git diff
替换本地改动
如果操作失误,可以使用命令git checkout – 替换掉本地改动。该命令会使用 HEAD中的最新内容替换掉工作目录中的文件(已添加到暂存区的改动以及新文件都不会受到影响)
远程仓库的移除和重命名
将test重命名为test1:git remote rename test test1
移除远程仓库test1: git remote rm test1
撤销操作
取消暂存的文件:git reset filename
撤销对文件的修改:git checkout –filename
历史纪录
使用git log可以得到本地仓库的历史记录。
使用命令git log --author=bob来只看某个人的提交记录。添加一些参数来修改输出,从而得到自己想要的结果。
查看哪些文件改变了: git log --name-status
推荐学习:《Git教程》
以上是一文带你读懂什么是Git版本管理的详细内容。更多信息请关注PHP中文网其他相关文章!

GitHub是一个面向开源及私有软件项目的托管平台,可以让开发者们在这里托管自己的代码,并进行版本控制。GitHub主打的是开源项目与协作,通过这个平台上的开源项目,开发者们可以查看其他开发者的项目源代码,并进行交流和学习。

在git中,“push -u”的意思是将本地的分支版本上传到远程合并,并且记录push到远程分支的默认值;当添加“-u”参数时,表示下次继续push的这个远端分支的时候推送命令就可以简写成“git push”。

GitLab是一种基于Web的Git版本控制库管理软件,旨在帮助开发团队更好地协同工作,提高工作效率。当您第一次登录GitLab时,系统会提示您要更改初始密码以确保账户安全。本文将为大家介绍如何在GitLab上进行第一次登录并更改密码。

在git中,pack文件可以有效的使用磁盘缓存,并且为常用命令读取最近引用的对象提供访问模式;git会将多个指定的对象打包成一个成为包文件(packfile)的二进制文件,用于节省空间和提高效率。

git中pull失败的解决方法:1、利用“git reset --hard”强制覆盖掉自己的本地修改;2、利用“git stash”推送一个新的储藏,拉取之后利用“git stash pop”将修改保存到暂存区;3、若依然出现问题,则将文件保存到暂存区并提交注释即可。

git分支能改名字。改名方法:1、利用git中的branch命令修改本地分支的名称,语法为“git branch -m 旧名字 新名字”;2、利用“git push origin 新名字”命令,在删除远程分支之后将改名后的本地分支推送到远程;3、利用IDEA直接操作修改分支名称即可。

git删除某个分支的方法:1、利用“git branch --delete dev”命令删除本地分支;2、利用“git push origin --delete branch”命令删除远程分支;3、利用“git branch --delete --remotes”命令删除追踪分支。

本篇文章给大家带来了关于git的相关知识,其中主要跟大家聊一聊怎么让你的git记录保持整洁,感兴趣的朋友下面一起来看一下吧,希望对大家有帮助。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

SublimeText3 Linux新版
SublimeText3 Linux最新版

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

WebStorm Mac版
好用的JavaScript开发工具

SublimeText3 英文版
推荐:为Win版本,支持代码提示!