热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

git基本用法教程(fork软件+git命令)

git基本用法教

git基本用法教程

  • 1. git commit
  • 2. git branch
  • 3. git checkout
  • 4. git merge
  • 5. git rebase
  • 6. 在提交树中移动
  • 7. 撤销变更
  • 8. 整理提交记录
  • 9. 提交的技巧
  • 10. git clone
  • 11. git push
  • 12. git pull
  • 13. git fetch
  • 14. git flow
  • 15. git stash
  • 16. fork的使用



当然除了环境和demo的运行和改写,work flow中当然少不了git的参与!

git使得开发的流程更加清晰,main, develop,release,feature,bugFix等branch的通力合作,使得项目可以更快,更高效的推进和整合。这里简单介绍下git的一些用法和语法,并且推荐大家使用fork进行本地项目的管理(当然使用原生的git也可以,原生的GUI不如fork友好,但是经验老道的程序员命令行用的嘎嘎飞起,分支流程都梳理的清楚,用啥都行~)
1. git commit

版本比对,将差异打包到一起作为一个提交记录

git保存提交的历史记录

语法:git commit 【一些本次提交的相关信息】

ps:注意这里只是将暂存区文件上传到本地代码仓库,并没有直接推向远端仓库

2. git branch

使用分支相当于:我想基于这个提交以及它所有父类提交进行新工作

语法:git branch branch_name

git branch -f main HEAD~3:将main分支强制指向HEAD的第三级父提交

3. git checkout

语法:git checkout nodeName

将当前节点切换到分支上

快捷创建分支并切换:

git checkout -b branchName

4. git merge

合并两个分支——新建一个分支,在其开发某个新功能,开发完成后再合并回主线。

merge合并两个分支:把两个父节点本身及他们的所有祖先包含进来

具体操作:将多个同名文件合并为同一个文件,该文件包含多个同名文件的所有内容,相同内容抵消

5. git rebase

提取一系列的提交记录,进行”复制“,在另外一个地方逐个放下

可以创造更线性的提交历史

语法:git rebase NodeName

将当前节点复制并放在NodeName的下方

6. 在提交树中移动

head——一个对当前所在分支的符号引用——指向正在其基础上进行工作的提交记录

head总是指向当前分支上最近的一次提交记录。通常指向分支名

分离的head让其指向了一个具体的提交记录而不是分支名

HEAD-> main -> C1

git checkout C1后变成:

HEAD -> C1

通过制定提交记录的哈希值(示例中为C1)在git中移动不方便,因为哈希值在git中会很长(基于SHA-1 40位),可以使用git log查看提交记录的哈希值

相对引用—:

^:向上移动1个提交记录

~num:向上移动多个提交记录

7. 撤销变更

git reset:通过把分支记录回退几个提交记录来实现撤销改动。改写历史,原来指向的提交记录就跟从来没有提交过一样。

git reset HEAD~1

git revert:这种改写历史的方法对大家一起使用的远程分支是无效的!

为了撤销更改并分享给别人,我们需要使用git revert:

更改为了撤销该提交(所以这里会自动git commit一个新”撤销“的版本),revert之后就可以把你的更改推送到远程仓库中

git revert HEAD

8. 整理提交记录

git cherry-pick 《提交号》

git cherry-pick C2 C4

交互式的rebase——从一系列提交记录中找到想要的记录

git rebase --interactive(-i)

会调用rebase UI界面,完成三件事:

调整提交记录的顺序

删除不想要的提交(切换pick的状态完成

合并提交

9. 提交的技巧

情况:分支上进行了一次提交,基于它创建了新分支,再次提交,此时想对以前某个提交记录进行调整:

git rebase -i

git commit --amend

git rebase -i

10. git clone

克隆远端仓库

语法:git clone https://xxx

从远程仓库URL加载创建一个与远程仓库一样的本地仓库

11. git push

推送将本地仓库同步到远端仓库中,一般推送(push)前先拉取(pull)一次,确保一致

12. git pull

从远程仓库获取信息并同步至本地仓库,并且自动执行合并(merge)操作

git pull = git fetch + git merge

13. git fetch

从远程仓库获取信息并同步至本地仓库

14. git flow

团队工作时,每个人创建属于自己的分支branch,确认无误后提交到master分支上

15. git stash

将本地工作空间所有的修改暂存到stash中,并且随时可以取出、一般应用于解决冲突和切换分支的场景下

16. fork的使用

我们在这里https://git-fork.com/下载mac或Windows版本的fork,直接安装就行。
界面入图所示:
在这里插入图片描述
对于fork的操作后续补充~


推荐阅读
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • 本文详细介绍了git常用命令及其操作方法,包括查看、添加、提交、删除、找回等操作,以及如何重置修改文件、抛弃工作区修改、将工作文件提交到本地暂存区、从版本库中删除文件等。同时还介绍了如何从暂存区恢复到工作文件、恢复最近一次提交过的状态,以及如何合并多个操作等。 ... [详细]
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • Android源码深入理解JNI技术的概述和应用
    本文介绍了Android源码中的JNI技术,包括概述和应用。JNI是Java Native Interface的缩写,是一种技术,可以实现Java程序调用Native语言写的函数,以及Native程序调用Java层的函数。在Android平台上,JNI充当了连接Java世界和Native世界的桥梁。本文通过分析Android源码中的相关文件和位置,深入探讨了JNI技术在Android开发中的重要性和应用场景。 ... [详细]
  • 本文讨论了在Windows 8上安装gvim中插件时出现的错误加载问题。作者将EasyMotion插件放在了正确的位置,但加载时却出现了错误。作者提供了下载链接和之前放置插件的位置,并列出了出现的错误信息。 ... [详细]
  • 本文介绍了C#中数据集DataSet对象的使用及相关方法详解,包括DataSet对象的概述、与数据关系对象的互联、Rows集合和Columns集合的组成,以及DataSet对象常用的方法之一——Merge方法的使用。通过本文的阅读,读者可以了解到DataSet对象在C#中的重要性和使用方法。 ... [详细]
  • 本文介绍了使用PHP实现断点续传乱序合并文件的方法和源码。由于网络原因,文件需要分割成多个部分发送,因此无法按顺序接收。文章中提供了merge2.php的源码,通过使用shuffle函数打乱文件读取顺序,实现了乱序合并文件的功能。同时,还介绍了filesize、glob、unlink、fopen等相关函数的使用。阅读本文可以了解如何使用PHP实现断点续传乱序合并文件的具体步骤。 ... [详细]
  • HDFS2.x新特性
    一、集群间数据拷贝scp实现两个远程主机之间的文件复制scp-rhello.txtroothadoop103:useratguiguhello.txt推pushscp-rr ... [详细]
  • 本文介绍了在Vue项目中如何结合Element UI解决连续上传多张图片及图片编辑的问题。作者强调了在编码前要明确需求和所需要的结果,并详细描述了自己的代码实现过程。 ... [详细]
  • Redis底层数据结构之压缩列表的介绍及实现原理
    本文介绍了Redis底层数据结构之压缩列表的概念、实现原理以及使用场景。压缩列表是Redis为了节约内存而开发的一种顺序数据结构,由特殊编码的连续内存块组成。文章详细解释了压缩列表的构成和各个属性的含义,以及如何通过指针来计算表尾节点的地址。压缩列表适用于列表键和哈希键中只包含少量小整数值和短字符串的情况。通过使用压缩列表,可以有效减少内存占用,提升Redis的性能。 ... [详细]
  • 本文介绍了一道网络流题目hdu4888 Redraw Beautiful Drawings的解题思路。题目要求以行和列作为结点建图,并通过最大流算法判断是否有解以及是否唯一。文章详细介绍了建图和算法的过程,并强调在dfs过程中要进行回溯。 ... [详细]
  • 本文介绍了在使用FIS配置过程中遇到的问题以及解决方法。作者发现在配置roadmap时使用命令行参数出现了诡异现象,uglify了js文件后,html中对js的引用没有被修改。经过多次尝试和验证,联系了FIS开发人员后才得知,使用fis.config.merge会导致一些问题。通过将fis.config.merge改为fis.config.get('roadmap.path').unshift()来添加配置,问题得以解决。文章指出FIS官方文档解释不够详细,提供了解决问题的方法。 ... [详细]
  • SpringMVC接收请求参数的方式总结
    本文总结了在SpringMVC开发中处理控制器参数的各种方式,包括处理使用@RequestParam注解的参数、MultipartFile类型参数和Simple类型参数的RequestParamMethodArgumentResolver,处理@RequestBody注解的参数的RequestResponseBodyMethodProcessor,以及PathVariableMapMethodArgumentResol等子类。 ... [详细]
  • 十大经典排序算法动图演示+Python实现
    本文介绍了十大经典排序算法的原理、演示和Python实现。排序算法分为内部排序和外部排序,常见的内部排序算法有插入排序、希尔排序、选择排序、冒泡排序、归并排序、快速排序、堆排序、基数排序等。文章还解释了时间复杂度和稳定性的概念,并提供了相关的名词解释。 ... [详细]
  • Ihaveaworkfolderdirectory.我有一个工作文件夹目录。holderDir.glob(*)>holder[ProjectOne, ... [详细]
author-avatar
许琼博762375
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有