版本管理最好用的工具,你懂多少?(版本管理工具有哪些)

版本控制(Revision control)是一种在开发的过程中用于管理我们对文件、目录或工程等内容的修改历史,方便查看更改历史记录,备份以便恢复以前的版本的软件工程技术。

简单来说,版本控制就是用于管理多人协同开发项目的技术。下面要讲的是一个名为Git的版本控制器。

Git的下载:直接在git官网下载的话可能会有点慢,推荐使用淘宝镜像下载:CNPM Binaries Mirror

我的windows系统,安装起来直接下一步下一步的操作就可以了。

具体学习资料,可以到官方文档上学习下,我总结了一些面试常问的相关知识点,如果都掌握了,就基本没有什么问题了。

1、Git是什么使用什么语言编写的?

git使用的是C语言编写的,git很快,c语言通过减少运行的开销来做到这一点。

2、git如何查看所有分支?

A. git status B. git reflog C. git branch -a D. git log

正确答案: C

3、 如何创建分支?

A. git branch 分支 B. git create 分支 C. git pull 分支 D. git push 分支

正确答案: A

4、 如何跳转已经存在的分支?

A. git checkout 分支名 B. git add 分支名 C. git push 文件名 D. git rm 文件名

正确答案: A

5、 使用git管理代码如何推送到远程?

A. git add

B. git commit

C. git pull

D. git push origin master

正确答案: D

6、 git 查看提交日志的命令是?

A. git commit

B. git reflog

C. ssh-keygen

D. netstat -anp

正确答案: B

7、 在git中如何跳转指定版本?

参考答案:

1. git reflog —查看日志

2、git reset –hard 版本号

8、 Git 和 SVN 有什么区别?

Git

SVN

1. Git 是一个分布式的版本控制工具

1. SVN 是集中版本控制工具

2. 它属于第 3 代版本控制工具

2. 它属于第 2 代版本控制工具

3. 客户端可以在其本地系统上克隆整个存储库

3. 版本历史记录存储在服务器端的存储库中

4. 即使离线也可以提交

4. 只允许在线提交

5.Push/pull 操作更快

5.Push/pull 操作较慢

6. 工程可以用 commit 自动共享

6. 没有任何东西能自动共享

9、 Git pull 和 Git fetch 有什么区别?

Git pull 命令从中央存储库中提取特定分支的信息更改或提交, 并更新本地存储库中的目标分支.

Git fetch 也用于相同的目的, 但它的工作方式略有不同. 当你执行 Git fetch 时, 它会从所需的分支中提取所有新提交, 并将其存储在本地存储库中的新分支中. 如果要在目标分支中反映这些更改, 必须在 Git fetch 之后执行 Git merge. 只有在对目标分支和获取的分支进行合并后才会更新目标分支. 为了方便起见, 请记住以下等式:

Git pull = Git fetch Git merge

10. 什么是 Git stash?

首先应该解释 Git stash 的必要性.

通常情况下, 当你一直在处理项目的某一部分时, 如果你想要在某个时候切换分支去处理其他事情, 事情会处于混乱的状态. 问题是, 你不想把完成了一半的工作的提交, 以便你以后就可以回到当前的工作. 解决这个问题的答案是 Git stash.

再解释什么是 Git stash.

stash 会将你的工作目录, 即修改后的跟踪文件和暂存的更改保存在一堆未完成的更改中, 你可以随时重新应用这些更改

版本管理最好用的工具,你懂多少?(版本管理工具有哪些)

常用命令总结:

# 提交修改三步 add ,commit, push.Git pull

拉取资源。

# 切换回 devGit checkout dev###################Git 检出其他分支的某个文件到当前分支并提交 ############Git checkout **.javaGit statusGit add **.javaGit commit -m ''Git pushGit lg#############Git 如何让单个文件回退到指定的版本 ########1. 进入到文件所在文件目录, 或者能找到文件的路径, 查看文件的修改记录

回退到指定的版本

#3. 提交到本地参考Git commit -m "注释"#4. 更新到工作目录Git checkout **.java#5. 提交到远程仓库Git push origin master#6. 撤销回退到合并之前的远程 dev 版本Git reset --hard dev#7. 显示提交更改内容Git show

还有一些很有用但是不常用的命令:

git log -p -1 查询最近一次的文件更改.

git diff 查看已暂存和未暂存修改

git rm fileName 从 Git 仓库中删除

git reset HEAD README.md 可以取消暂存再次查看文件状态被修改的文件变成 unstaged 状态

添加远程仓库:

Git remote add <libraryName> <url>$ Git remote add test https://libraryUrl/demo/demo.Git$ Git remoteorigintest

远程仓库中抓取与拉取

$ Git fetch [remote-name]

这个命令会访问远程仓库, 从中拉取所有你还没有的数据. 执行完成后, 你将会拥有那个远程仓库中所有分支的引用, 可以随时合并或查看.

推送到远程仓库

Git push [remote-name] [branch-name]

, 下面是推送当前分支到远程的 master 分支

$ Git push origin master

打标签

像其他版本控制系统 (VCS) 一样, Git 可以给历史中的某一个提交打上标签, 以示重要.

查看所有标签 Git tag。

git cherry-pick

命令git cherry-pick 通常用于把特定提交从存储仓库的一个分支引入到其他分支中。常见的用途是从维护的分支到开发分支进行向前或回滚提交。
合并(merge) 变基(rebase)

forking的工作流程的优点

它不是用单个服务端仓库充当“中央”代码库,而是为每个开发者提供自己的服务端库。forking工作流程最常用于公共开源项目中。

Forking工作流程的主要优点是可以汇集提交贡献,又无需每个开发者提交到一个中央仓库中,从而实现干净的项目历史记录。开发者可以推送代码到自己的服务端仓库,而只有项目维护人员直接推送代码到官方仓库中。

当开发者准备发布本地提交时,他们的提交会推送到自己的公共仓库中,而不是官方仓库中。 需要发布则提交合并请求,他们向主仓库请求拉取(pull request),项目维护人员(合并人)还可以对项目进行审核更新。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

(0)
上一篇 2022年5月28日 上午9:07
下一篇 2022年5月28日 上午9:16

相关推荐

  • 母婴店收银系统哪个好?你应该从营销管理着手(母婴店用什么收银系统好)

    纵观全行业,母婴行业算是走在了发展的前沿。可能有人会说,母婴店并不好做,商品经常滞销。可是换个方面,除了不可抗拒的因素外,运营者应该借助外部力量,来提高效率,其中收银系统就是一个很…

    科研百科 2022年11月7日
    379
  • 上海理工科研项目

    上海理工科研项目: 探索太空中的纳米材料 近年来,随着科技的不断发展,太空探索已经成为了全球各国的热门话题。上海理工作为一家具有创新精神的高校,也在不断地开展着相关的科研项目。 在…

    科研百科 2025年3月30日
    2
  • 产品研发项目管理系统

    产品研发项目管理系统 随着科技的不断进步,企业对于产品研发的投入也越来越大。然而,传统的手工管理方式已经无法满足现代企业的需求,因此,产品研发项目管理系统应运而生。 产品研发项目管…

    科研百科 2024年7月15日
    16
  • 煤炭购销合同管理

    煤炭购销合同管理 煤炭作为我国的主要能源来源之一,其购销合同管理也具有重要的现实意义。煤炭购销合同管理是保证煤炭生产和供应的重要环节,对于维护市场稳定、保障经济秩序、促进经济发展都…

    科研百科 2024年9月25日
    3
  • 医院科研项目获批通知书

    医院科研项目获批通知书 近日,我们收到了医院科研项目获批通知书,这是我们团队多年来的努力和奋斗的成果。在此,我代表团队向医院领导和相关部门表示热烈的祝贺! 医院科研项目获批通知书是…

    科研百科 2025年1月31日
    8
  • 微信外卖小程序怎么做?外卖小程序制作需要多少费用?(微信外卖小程序制作要多少钱)

    现如今随着大家的生活水平提高,人们对生活质量也是有着越来越高的要求,例如餐饮为方便用户就餐,便开始通过线上小程序搭建外卖点餐系统,极大程度提高了顾客的购买欲望。那么如何搭建一套自己…

    科研百科 2023年4月5日
    262
  • 科研项目公示未立项

    科研项目公示未立项 近年来,随着科技的快速发展,科研项目立项已经成为一项非常必要的工作。然而,有些科研项目在立项过程中遇到了一些问题,其中最为典型的就是公示未立项。这种现象的出现,…

    科研百科 2025年2月28日
    3
  • .NET 大数据可视化平台

    .NET 大数据可视化平台:让数据更有趣 随着大数据时代的到来,越来越多的公司和个人开始利用数据来推动业务创新和提高效率。但是,如何有效地将这些数据可视化并不是一件容易的事情。传统…

    科研百科 2024年11月28日
    6
  • cad如何加载探索者

    CAD是一款广泛使用的三维计算机辅助设计软件,它可以用于绘制建筑、机械和其他领域的图形。在CAD中,探索者模块是一个非常重要的工具,它可以帮助用户快速访问和编辑特定区域。本文将介绍…

    科研百科 2024年10月14日
    35
  • 事务所项目管理软件

    事务所项目管理软件 随着现代审计行业的发展,事务所成为了审计领域中不可或缺的一部分。但是,传统的手工记录和管理方式已经无法满足现代审计的需求。因此,事务所项目管理软件应运而生。本文…

    科研百科 2024年7月21日
    4