Git项目管理

Git简介

  • Git是一种开源的分布式版本控制系统

几种常用的版本控制系统优缺点比较

VSS

  • VSS 的全称为 Visual Source Safe。作为 Microsoft Visual Studio 的一名成员,它主要任务就是负责项目文件的管理,几乎可以适用任何软件项目。管理软件开发中各个不同版本的源代码和文档,占用空间小并且方便各个版本代码和文档的获取,对开发小组中对源代码的访问进行有效的协调
  • VSS作为一款历史悠久的版本管理工具,能帮助解决一部分版本控制方面的问题,也在一定程度上帮助解决代码共享方面的难题。但是依旧存在一些不足:
  1. 文件大多会以独占的形势进行锁定。如果一个人在修改的时候其他人没有办法进行修改。
  2. VSS只支持Windows版本,且只兼容微软的开发工具。
  3. 文件存储,服务器必须共享文件夹,对文件的安全性没有足够保障。

SVN

SVN是Subversion的简称,是一个开放源代码的版本控制系统,相较于RCS、CVS,它采用了分支管理系统,它的设计目标就是取代CVS。SVN就是用于多个人共同开发同一个项目,共用资源的目的。
优点

  1. 管理方便,逻辑明确,操作简单,上手快。
  2. 易于管理,集中式服务器更能保证安全性。
  3. 代码一致性非常高。
  4. 有良好的目录级权限控制系统。
    劣势
  5. 对服务器性能要求高,数据库容量经常暴增,体量大。
  6. 必须联网。如果不能连接到服务器上,基本上不可以工作,如果服务器不能连接上,就不能提交,还原,对比等等。
  7. 不适合开源开发。

Git

Git实现上传代码到GitHub

参考这篇博客:Git如何实现上传代码到GitHub
首先需要配置GitHub和本地库,然后进行代码上传,用到的命令包括有:

  1. 在git bash中输入命令
git add .  // .表示上传所有
git commit -m "上传文件的解释"

上述代码含义:

  • git add . :将工作区代码添加到待提交区,.表示提交所有。
  • git commit -m " "是将代码从待提交区提交到本地
    Git项目管理_第1张图片
  1. 从远程拉取一下代码 ,此步操作可以没有,但我个人而言最好加上,是为了不让产生冲突,如果没事 也就多写一行代码而已,如果少了这步出现冲突就不划算了
git pull origin master

git pull origin master 是从远程服务器拉取代码到本地仓库
3. push到GitHub

git push origin master

Git常用命令

  • 查看、添加、提交、删除、找回,重置修改文件
git help <command> # 显示command的help

git show # 显示某次提交的内容 git show $id

git co -- <file> # 抛弃工作区修改

git co . # 抛弃工作区修改

git add <file> # 将工作文件修改提交到本地暂存区

git add . # 将所有修改过的工作文件提交暂存区

git rm <file> # 从版本库中删除文件

git rm <file> --cached # 从版本库中删除文件,但不删除文件

git reset <file> # 从暂存区恢复到工作文件

git reset -- . # 从暂存区恢复到工作文件

git reset --hard # 恢复最近一次提交过的状态,即放弃上次提交后的所有本次修改

git ci <file> git ci . git ci -a # 将git add, git rm和git ci等操作都合并在一起做 git ci -am "some comments"

git ci --amend # 修改最后一次提交记录

git revert <$id> # 恢复某次提交的状态,恢复动作本身也创建次提交对象

git revert HEAD # 恢复最后一次提交的状态
  • 查看文件diff
git diff <file> # 比较当前文件和暂存区文件差异 git diff

git diff <id1><id2> # 比较两次提交之间的差异

git diff <branch1>..<branch2> # 在两个分支之间比较

git diff --staged # 比较暂存区和版本库差异

git diff --cached # 比较暂存区和版本库差异

git diff --stat # 仅仅比较统计信息
  • 查看提交记录
git diff <file> # 比较当前文件和暂存区文件差异 git diff

git diff <id1><id2> # 比较两次提交之间的差异

git diff <branch1>..<branch2> # 在两个分支之间比较

git diff --staged # 比较暂存区和版本库差异

git diff --cached # 比较暂存区和版本库差异

git diff --stat # 仅仅比较统计信息

你可能感兴趣的:(Git,git,c语言,c++)