git 和 svn 区别

入职到新公司,代码版本控制工具由svn转变成git了,不是很适应。按照使用频率依次递减的原则,总结一下二者的差别,才能更好的学会使用。从2个维度进行总结。

1,有无中心服务器。svn有,git无。

svn在中心服务器上存储所有代码,只要你不update就不会和服务器同步。并且,存储的每个版本的文件,与初始版本文件的差异。git没有中心服务器的概念,在所有用户的本地都保存了所有文件。并且,存储的是对所有文件的快照。

2,相同操作,在svn和git中命令的区别。

2.1,如何使得文件夹在版本控制之下:svn在文件夹内添加.svn隐藏文件,git在文件夹内添加.git隐藏文件

2.2,如何检查是否有更改:svn的文件修改标记显而易见。git:通过"git status"命令获取,"-"符号代表修改前文件,"+"符号代表修改后文件

2.3,如何初次获取仓库代码:svn通过tortoise客户端checkout某url,git通过"git clone [--recurse-submodules] url [name]"命令获取

2.4,如何提交代码:svn通过客户端的commit提交代码,git通过"git commit -m detailedInfo"将暂存区文件提交到仓库,或者"git commit -a -m detailedInfo"将把所有已经跟踪过的文件暂存起来一并提交,从而跳过git add步骤

2.5,如何把新增的本地文件变成暂存状态:svn通过+号,git通过 "git add filename" / "git add -A"将某个文件、或者所有修改的文件添加到暂存区

2.6,如何查看日志:svn通过客户端show log查看,git通过"git log --pretty=oneline"查看

2.7, 如何比较差异:svn通过客户端show diff查看,git通过:git diff 比较的是暂存区和工作区的差异;git diff --cached 比较的是暂存区和历史区的差异;git diff master 比较的是历史区和工作区的差异(修改)。显示的差异是当前本地文件与上一次commit后的文件的区别

2.8, 如何回退版本:svn通过客户端执行revert进行版本回退,git通过"git reset --hard HEAD^"回退到上一个版本。需要介绍一点,HEAD表示当前版本,HEAD^表示上一个版本,HEAD^^表示上两个版本,HEAD~100表示前面第100个版本。总结就是通过"git reset --hard commit_id",利用commit_id回退版本。 可以通过"git reflog"命令查看提交过的所有版本的版本号

2.9,如何撤销本地修改:svn通过客户端进行show diff,一句一句看到本地所做的修改,然后可以逐句操作。git通过"git checkout -- readme.txt"命令readme.txt文件在工作区的修改全部撤销,这里有两种情况:一种是readme.txt自修改后还没有被放到暂存区,现在,撤销修改就回到和版本库一模一样的状态;一种是readme.txt已经添加到暂存区后,又作了修改,现在,撤销修改就回到添加到暂存区后的状态。总之,就是让这个文件回到最近一次git commitgit add时的状态。

2.10,如何从仓库中删除文件:svn通过客户端来执行delete来删除,git通过"git rm filename" 命令删除

git特有的:

1,如何取消暂存区的修改:命令“git reset HEAD file"可以把暂存区的修改撤销掉(unstage),重新放回工作区

以上只包含git的本地操作,未涉及远程仓库。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值