当前位置:首页 > 技术分析 > 正文内容

版本管理最好用的工具,你懂多少?

ruisui884个月前 (02-03)技术分析28


版本控制(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

拉取资源。

# 切换回 dev
Git checkout dev
###################Git 检出其他分支的某个文件到当前分支并提交 ############
Git checkout **.java
Git status
Git add **.java
Git commit -m ''
Git push
Git 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  
$ Git remote add test https://libraryUrl/demo/demo.Git
$ Git remote
origin
test

远程仓库中抓取与拉取

$ 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),项目维护人员(合并人)还可以对项目进行审核更新。

扫描二维码推送至手机访问。

版权声明:本文由ruisui88发布,如需转载请注明出处。

本文链接:http://www.ruisui88.com/post/1280.html

分享给朋友:

“版本管理最好用的工具,你懂多少?” 的相关文章

Slackware 15.0?发布:历史最久且在维护的Linux发行版本

Slackware 14.0 于 2012 年发布,在经过了数年的等待之后 Slackware 15.0 发行版本于今天正式发布。Slackware 于 1993 年发布,是目前历史最悠久、且仍在维护的 Linux 发行版本。Slackware 15.0 在去年进入测试阶段,在发布几个候选版本之后终...

首个支持苹果 M1 Mac 的 Linux 发行版发布,面向用户开放下载

IT之家 3 月 20 日消息,Asahi Linux 是研究 Linux for Apple Silicon macs 的组织群体,3 月 18 日,Asahi Linux 宣布成功在 M1 MacBook Air 笔记本电脑上运行,并开放了 Asahi Linux 的下载安装。Asahi Lin...

Git分布式系统---Gitlab多人工作流程

前言在上一次推文中,我们已经很清楚的讲解了如何创建本地仓库、提交(push)项目到远程仓库以及从远程仓库clone(克隆)项目到本地的相关操作。大家可以先去看前面的推文(快速掌握Git分布式系统操作)点击查看目前无论你是否步入社会还是在校学生,都会使用Gitlab来进行团队的代码管理。(可以这样说:...

Vue页面传参详解

一、两种方式方法1:name跳转页面this.$router.push({name:'anotherPage',params:{id:1}})另一页面接收参数方式:this.$route.params.id示例:控制台展示:方法2:path跳转页面this.$router.push(...

Vue从入门到实践 丨Vue-router基本使用

1. 什么是 vue-routervue-router 是 vue.js 官方给出的路由解决方案。它只能结合 vue 项目进行使用,能够轻松的管理 SPA 项目中组件的切换。vue-router 的官方文档地址:https://router.vuejs.org/zh/2. vue-router 安装...

TDesign企业级开源设计系统越发成熟稳定,支持 Vue3 / 小程序

TDesing 发展越来越好了,出了好几套组件库,很成熟稳定了,新项目完全可以考虑使用。早在2021年,腾讯的 TDesing 刚发布不久,我就写了一篇简短的文章来介绍,当时主要关注的是 TDesign 的 Vue 组件库和用来搭建 admin 后台系统的实用性。虽然当时看起来不错,但还处于测试版,...