实验目的:

1)了解分布式版本控制系统的核心机理;

2)   熟练掌握git的基本指令和分支管理指令;

实验内容:

1)安装git

2)初始配置git ,git init git status指令

3)掌握git log ,git add ,git diff 指令

4) 掌握git tag git branch,git commit 指令

5)掌握git revert 指令

实验记录:

1)实验内容以及结果的截图:

2)实验过程中发生的问题与解决。

1.安装git与初始配置

配置用户名,邮箱,以及确保 Git 输出内容带有颜色标记。与代码编辑器Sublime 进行链接。

2.从头创建仓库

   2.1创建项目目录

创建一个目录: se2020-git-course,在该目录中,创建另一个目录: new-git-project,使用 cd 命令移到 new-git-project 目录下。

运行git init,在当前目录下生成一个空的Git仓库。

 2.2克隆现有仓库

输入命令 git clone,然后输入你要克隆的 Git 仓库的路径。本次实验路径为 :https://github.com/udacity/course-git-blog-project 。

    2.3判断仓库现有状态

git status 是了解 Git 的核心所在。它将告诉我们 Git 正在考虑什么,以及 Git 所看到的我们仓库的状态。

思考:如何证明库尚无任何commit.

运行git log,结果如下:

3.git log 命令

git log 命令用于显示仓库中所有 commit 的信息。默认情况下该命令会显示仓库中每个 commit 的:SHA、作者、日期、消息

   3.1git log --oneline命令

 git log --oneline,可以用来更改仓库信息的显示方式。

  3.2git log --stat命令

git log --stat,用来显示 commit 中更改的文件以及添加或删除的行数。

此命令会:1.显示被修改的文件

2.显示添加/删除的行数

3.显示一个摘要,其中包含修改/删除的总文件数和总行数

3.3git log -p 命令

git log -p 命令可用来显示对文件作出实际更改的命令。

此命令会:1.显示被修改的文件

2.显示添加/删除的行所在的位置

3.显示做出的实际更改

 3.4git show 命令

仅显示一个特定的commit,方便查阅。

 4.git add& git commit&git diff

4.1创建HTML文件,文件名为index.html,并添加一些初始代码。

建立js和css文件夹,并在文件夹下分别建立app.js和app.css文件,文件内容可为空。

输入git status 查看状态

4.2git add

将index.html添加到暂存区,并利用 git status查看

显示index.html被成功加入到暂存区。

再暂存另外两个文件。现在我们可以运行以下命令:

$ git add css/app.css js/app.js

或者使用 git add .   ( 句点指代当前目录,可以用来表示所有文件和目录(包括所有嵌套文件和目录!))。

4.3 git commit

要在 git 中提交 commit,你需要使用 git commit 命令,但是先别运行这条命令。运行这条命令将会打开你在第一节课配置的代码编辑器。

4.4 使用 -m 选项绕过编辑器

在index.html 中的body标记中加入

<header>

<h1><Expedition></h1>

</header>

运行git status

将index.html 文件添加到暂存区,并运行git status查看是否已经保存。

使用 git commit 命令提交 commit,并添加提交说明 Add header to blog。

然后运行git log 查看刚刚提交的commit 说明。

4.5git diff

 此工具可以在进行提交之前告诉我们已对文件进行了什么样的更改。

用git diff 命令来查看已加入但是尚未提交的更改。在index.html中将标题改为Adventure,保存后在终端上运行git diff。

4.6  .gitignore

如果你想将某个文件保留在项目的目录结构中,但是确保它不会意外地提交到项目中,可以使用名称特殊的文件 .gitignore

(注意文件名开头的点,很重要!)。

在目录下新建word 文件夹project.docx.当运行git status 时会出现在文件目录上。

此时在文件new-git-project文件中添加 .gitignore 文件,并在文件中添加 project.docx,再次运行git status 将不会再出现

在文件目录中。

5. 标签与分支

5.1git tag 命令

进入,前面建立的 new-git-project 项目文件夹中。

5.1.1创建标签

使用 git tag 命令与仓库的标签进行交互,输入以下命令 :git tag -a v1.0

5.1.2 验证标签

保存并退出编辑器后,命令行上什么也不会显示。只需输入 git tag,命令行会显示仓库中的所有标签。

然后运行 git log 查看标签的位置

5.1.3删除标签

可以通过输入 -d 选项 (表示 delete 删除!)加上标签名称来删除 git 标签:git tag -d v1.0

5.1.4向以前的 commit 添加标签

运行 git tag -a v1.0 将为最近的 commit 添加标签。

或提供要添加标签的 commit 的 SHA ,可以通过查询历史SHA git log --oneline,查找已经commit  的SHA。

输入 git tag -a v1.0 4d87b86添加标签

5.2git branch 分支

5.2.1 git branch 命令用来与 git 的分支进行交互:列出仓库所有的分支名称,创建新的分支,删除分支。

5.2.2创建分支

要创建分支,只需使用 git branch 并提供要创建的分支对应的名称。因此,如果你想创建一个叫做"sidebar"的分支,

只需运行以下命令:gti branch sidebar

但是当前分支仍然是master.

使用 git checkout命令你切换分支。

使用 git log --oneline查看。

5.2.3活跃分支

判断活跃分支的最快速方式是查看 git branch 命令的输出结果。活跃分支名称旁边会显示一个星号。

5.2.4删除分支

首先切换掉想要删除的分支,确保其不是当前分支,例如sidebar。

使用git checkout master命令。

然后在使用 git branch -d sidebar命令删除sidebar 分支。

删除提示:

1)如果某个分支上有任何其他分支上都没有包含的 commit(也就是这个 commit 是要被删除的分支独有的),git 不会删除该分支。

2)如果你创建了 sidebar 分支,向其添加了 commit,然后尝试使用 git branch -d sidebar 删除该分支,git 不会让你删除该分支,

因为你无法删除当前所在的分支。

3)如果你切换到 master 分支并尝试删除 sidebar 分支,git 也不会让你删除,因为 sidebar 分支上的新 commit 会丢失!要强制删除,

你需要使用大写的 D 选项 git branch -D sidebar

5.3 高效分支

前期准备

5.3.1分支实战

更改 1 - 添加页面颜色,确保位于 master 分支上,并向 css/app.css 添加以下内容:

更改 2 - 添加侧栏,我们向页面上添加一个侧栏

先使用命令 git log --oneline 查看commit。在输入git branch sidebar 4d87b86,向该commit添加分支。

最后切换到sidebar分支后,会发现之前在master中添加的 Set background color for page没有了 。

添加html文件

更改 3 - 更改 master 上的标题,切换到 master 分支并更新页面标题。

切换分支

保存 index.html 文件并进行 commit 以将此更改添加到仓库中。

 同时查看所有分支:git log --oneline  --graph --all

6.合并

将分支组合到一起称为合并

6.1合并指令

git merge 指令用来合并 git 分支:

6.2合并冲突

首先人为制造冲突。

更改master标签,并commit保存。

创建一个heading-update分支,使用git --oneline --graph --all查看,

保存heading-update commit。合并分支发生冲突。

运行git status查看

修改index.html解决冲突

7.撤销更改

7.1更改最后一个 commit,git commit --amend

7.2 还原commit :  git revert <SHA-of-commit-to-revert>

7.3重置

git reset 命令

git reset 命令用来重置(清除)commit: git reset <reference-to-commit>

git reset 的选项

git 根据所使用选项来判断是清除、暂存之前 commit 的更改,还是取消暂存之前 commit 的更改。这些选项包括:

  • 使用 --hard 选项清除 commit

  • 使用 --soft 选项将 commit 的更改移至暂存区

  • 使用 --mixed 选项取消暂存已被 commit 的更改

7.4备份分支

先创建一个分支用来备份 :git branch backup

 总结与体会:

因为以前对GIT从未有过任何了解,所以刚开始时根本无从下手,起初配置软件时,还不知道软甲的用处,在配置过程中就遇到了很多麻烦,经过网上查阅资料才对GIT有了进一步的了解,在完成配置后,根据实验你步骤的指导起初一步步的操作感觉还不是很难,因为刚开始还是很顺利的,但是在做到需要更换上一级文件目录时出现了问题,不知道需要用什么命令返回上一级目录,进故宫查阅资料,利用 cd ..\, 然后会弹出  >,这是直接回车即可返回上一级目录。在后来的操作中因为第一次使用GIT,实验过程一路磕磕绊绊,才得以完成,在解决合并冲突,人为制造合并冲突时,同样遇到了麻烦,经历了好几次的摸索,最后得以解决,其中heading-up的分支commit 为上一个的分支的,随机一个commit ,而我在实验中使用了与master更改时相同的commit ,导致无法产生冲突。

经过这次实验对GIT有了初步的认识与了解,对GIT软件的使用,以及GIT的语法命令有了更进一步的掌握,对建立仓库,添加commit,修改commit其中git status,git log --oneline.在对GIT的使用中起到很大作用,对编译者很友好,可以方便查询状态信息。

思考题:

  阅读维基百科和百度百科的Git词条,总结分布式版本控制系统的核心机理

答:Git是一个开源的分布式版本控制系统,可以有效、高速地处理从很小到非常大的项目版本管理。Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。分布式版本控制系统是一种有效、高速地处理从很小到非常大的项目版本管理系统。与它相对的是集中式版本控制系统。在分布式版本控制系统中客户端并不像集中式版本控制系统那样提取最新版本的文件快照,而是把代码仓库完整地镜像下来。这样的核心机理就轻松的解决了集中式版本控制系统中容易出现的也是很致命的中央服务器单点故障。分布式版本控制系统没有所谓的"中央服务器",每个人的电脑上都是一个完整的版本

库。通常分布式版本控制系统有一台"伪中央服务器",但是这个服务器的作用仅仅是用来方便"交换"大家的修改,没有它大家仍然可以正常工作。

软工 实验一 Git代码版本管理的更多相关文章

  1. 实验一 GIT 代码版本管理

    实验一  GIT 代码版本管理 实验目的: 1)了解分布式分布式版本控制系统的核心机理: 2)   熟练掌握git的基本指令和分支管理指令: 实验内容: 1)安装git 2)初始配置git ,git ...

  2. 实验一  GIT 代码版本管理

    实验一  GIT 代码版本管理 实验目的: 1)了解分布式分布式版本控制系统的核心机理: 2)熟练掌握git的基本指令和分支管理指令: 实验内容: 1)安装git 2)初始配置git ,git ini ...

  3. 软件工程实验一 Git代码版本管理

    实验一  GIT 代码版本管理 一.实验目的: 1)了解分布式分布式版本控制系统的核心机理: 2)熟练掌握git的基本指令和分支管理指令: 二.实验内容: 1)安装git: 2)初始配置git ,gi ...

  4. 实验一Git代码版本管理

    GIT代码版本管理 实验目的: 1)了解分布式分布式版本控制系统的核心机理: 2) 熟练掌握git的基本指令和分支管理指令: 实验内容: 1)安装git 2)初始配置git ,git init git ...

  5. 实验1 GIT代码版本管理

    (一)实验目的: 1)了解分布式分布式版本控制系统的核心机理: 2) 熟练掌握git的基本指令和分支管理指令: (二)实验内容: 1)安装git 2)初始配置git ,git init git sta ...

  6. 实验一 git代码版本管理

    实验目的 1. 了解分布式系统版本管理的核心机理. 2. 熟练掌握 git 的基本指令和分支管理指令. 实验内容 1. 安装 git.2. 初始化配置 git,git init ,git status ...

  7. 实验一&#160;&#160;GIT 代码版本管理

    实验一  GIT 代码版本管理 实验目的: 1)了解分布式分布式版本控制系统的核心机理: 2)   熟练掌握git的基本指令和分支管理指令: 实验内容: 1)安装git 2)初始配置git ,git ...

  8. [2019BUAA软工]第0次代码作业

    Visual Studio 单元测试的简单应用 写在前面   笔者根据作业的介绍以及Visual Studio 2017 文档的相关说明,进行了Visual Studio 单元测试的简单应用. Tip ...

  9. iOS - Git 代码版本管理

    1.Git Git 是用 C 语言开发的分布版本控制系统.版本控制系统可以保留一个文件集合的历史记录,并能回滚文件集合到另一个状态(历史记录状态).另一个状态可以是不同的文件,也可以是不同的文件内容. ...

随机推荐

  1. linux epoll 任务队列多线程模型

    /* * *EPOLL ET 触发必须使用非阻塞,LT触发可以阻塞/非阻塞. *read 函数 非阻塞读需 忙轮寻 soket关闭返回0,循环读完数据 *如果已经读完再读read返回 -1,errno ...

  2. nginx常见的面试题

    问题1:Nginx是用来干嘛的? Nginx是一个高性能的HTTP和反向代理服务器,这个基本是用来前端服务器集群后做负载均衡和动静分离用的. 负载均衡即是代理服务器将接收的请求均衡的分发到各服务器中, ...

  3. MySQL安装教程及Navicat连接MySQL报错:1251-Client does not support authentication protocol requested by server

    MySQL安装可参考: MySql 8.0.18安装 此参考文章后面涉及到的密码修改,对本标题碰到的错误同样适用. 本文先讲如何安装,在讲碰到的1251问题.要直接看解决方案的朋友可以直接通过目录链接 ...

  4. html为什么用雪碧图的优缺点

    CSS Sprite(雪碧图/精灵图) 1          概念解释 将小图标和背景图像合并到一张图片上,然后利用css的背景/定位来显示需要显示的图片部分. 2           优点 ① 减少 ...

  5. Mock相关知识和简单应用

    一.moco的简单应用 moco地址:https://github.com/dreamhead/moco api文档地址: https://github.com/dreamhead/moco/blob ...

  6. 用C语言实现的轴对称变换

    #include<stdio.h> main() { int i,p,n,k,f,c,h,g,w; ][]; ;i<=;i++) { ;p<=;p++) { a[i][p]=i ...

  7. 吴裕雄--天生自然python学习笔记:pandas模块导入数据

    有时候,手工生成 Pandas 的 DataFrame 数据是件非常麻烦的事情,所以我们通 常会先把数据保存在 Excel 或数据库中,然后再把数据导入 Pandas . 另 一种情况是抓 取网页中成 ...

  8. 花生壳的ddns 关键时刻又掉链子,准备迁到阿里万网

    https://www.oray.com/news/affiche/?aid=628 免费版花生壳服务故障 因免费版机房线路节点负荷突然暴增,导致花生壳免费版登录缓慢或异常,或出现域名指向到127.0 ...

  9. HDU1166 敌兵布阵 [线段树模板]

    题意:在序列中修改单点和查询区间和 #include<iostream> #include<cstdio> #include<cstring> #define ls ...

  10. springboot学习笔记:6.内置tomcat启动和外部tomcat部署总结

    springboot的web项目的启动主要分为: 一.使用内置tomcat启动 启动方式: 1.IDEA中main函数启动 2.mvn springboot-run 命令 3.java -jar XX ...