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

git学习笔记二

一,     版本控制Git是全量更新。Git的每一个版本中都包含所有的文件,比如从version1到version2,我只更新了A文件,但是version2中包含了修改后的所有文

一,      版本控制

Git是全量更新。Git的每一个版本中都包含所有的文件,比如从version1到version2,我只更新了A文件,但是version2中包含了修改后的所有文件(最新的)。这样可以时刻保证数据的完整性。

 

 

 

二,      Git的四种状态

 

 

1,         已修改(modifid)

2,         已暂存(staged)

3,         已提交(commited)

三,      操作

1,         删除本地git仓库(.git文件)

rm –rf .git

2,         查看当前git状态

Git status

3,         合并add和commit

Git commit –am “注释”

4,         把暂存区的内容回退(回退到工作区)

git rm - -cached hello.txt

或git reset HEAD hello.txt

添加到工作区:git add hello.txt

5,         删除已提交(commited)的文件

方式一:

git rm hello.txt  删除后的文件被放到了暂存区

然后再执行commit才算彻底删除:git commit –m “彻底删除hello.txt”

如果执行了git rm hello.txt后,后悔删除了,怎么办:

现在文件在暂存区,执行:git reset HEAD hello.txt ,

此时文件回到工作区了,然后再执行:git checkout - - hello.txt

 

方式二:

rm hello.txt  这是linux命令删除,

这时必须git add .   git commit 才彻底删除

6,         修改注释(提交时的注释写错了,怎么修改?)

git commit - -amend –m “新注释”

7,         忽略文件(.gitignore文件)

*通配任意字符

 

*.properties  忽略所有.properties文件

!b.proterties  除了b.proterties文件

 

 

8,         放弃对工作区的修改

git checkout - - hello.txt  撤销对工作区的修改。(有时候我们用ctrl +z 不能回退到没修改之前的状态,这个很有用)

     

9,         查看git日志

Git log  

Git log - -graph   图形化日志

Git log - -graph - -pretty=oneline - -abbrev-commit

git log -2 查看最近两次的提交

git log –pretty=oneline  日志在一行显示

git log – pretty=format:”%h - %an , %ar:%s” 自定义日志格式

10,      Linux命令

Ctrl + a 、ctrl + e  移动光标到头,尾

Ctrl + c  当前行写错了,放弃执行当前这一行

echo ‘hello’ > hello.txt  修改文件(覆盖)

查看文件内容 cat hello

四,      设置用户名密码

1,         命令

git config - -global  给整个计算机一次性设置,基本不用

git config - -system  给当前用户一次性设置,推荐

git config - -local  给当前项目一次性设置

优先级:local > system > global

2,         实际操作

进入到一个项目中,然后进入到 该项目的 .git目录下,执行:

git config - -local user.name “yourname”

git config - -local user.email “youremail”

进入到 .git目录下,打开config文件,可以看到用户名和密码被加入了,

存放在了.git目录下的config文件中

 

如果是给当前用户一次性设置:

那么需要:

cd ~  (进入了系统用户目录:/c/Users/yaming/.gitconfg)

cat .gitconfig   (用户的config文件,给用户设置邮箱和名字,就保存在这个文件里了)

git config - -system user.name “yourname”

git config - -system user.email “youremail”

 

删除用户名邮箱:

git config - -local - -unset user.name

git config - -local - -unset user.email

 

五,      分支操作

1,         命令

创建分支git branch branchen_ame

查看分支 git branch   (git branch –r  查看远程分支)

切换分支 git checkout branch_name

删除分支 git branch –d branch_name(删除前需要先合并到主分支)

强行删除 git branch –D branch_name

创建并切换分支 git ckeckout –b branch_name

合并分支(到master) git merge branch_name

查看分支最近一次提交的信息 git branch -v

2,         细节

如果在分支a中进行了写操作,但是此操作局限在工作区中进行(没有add,commit),在master中能够看到该操作。

如果分支a中进行了写操作,并进行了commit,则master中无法看到该文件。并且此时可以直接删除分支a。

3,         分支

分支是一个commit链,一条工作记录线

 

 

六,      分支合并与冲突

1,         分支指向commit, HEAD指向当前分支的头部(分支名)

 

 

2,         当切换到dev时,HEAD会指向dev

执行:git  checkout –b dev

 

 

 

3,         对dev分支进行两次commit后,此时dev在master的前面了

 

 

4,         把dev分支合并到master。Master就可以直接追赶上dev了。追赶这个动作称之为fast forward。fast forward 本质是指针的移动。

执行 git merge dev

 

 

合并后master和dev指向同一个commit

 

 

 

5,         分支冲突

解决冲突:修改文件

Git add .    git commit

七,      版本穿梭

1,         在多个commit之间进行穿梭。回退,前进

回退到上一次commit : git reset - -hard HEAD^

回退到上两次commit : git reset - -hard HEAD^^

回退到上n次commit : git reset - -hard HEAD~n

切换到任意commit处(通过sha1值,直接回退):git reset - -hard 850bc999(sha1值的前几位就行)

查看所有log:git reflog

 



推荐阅读
  • Gitlab接入公司内部单点登录的安装和配置教程
    本文介绍了如何将公司内部的Gitlab系统接入单点登录服务,并提供了安装和配置的详细教程。通过使用oauth2协议,将原有的各子系统的独立登录统一迁移至单点登录。文章包括Gitlab的安装环境、版本号、编辑配置文件的步骤,并解决了在迁移过程中可能遇到的问题。 ... [详细]
  • 解决github访问慢的问题的方法集锦
    本文总结了国内用户在访问github网站时可能遇到的加载慢的问题,并提供了解决方法,其中包括修改hosts文件来加速访问。 ... [详细]
  • 本文详细介绍了git常用命令及其操作方法,包括查看、添加、提交、删除、找回等操作,以及如何重置修改文件、抛弃工作区修改、将工作文件提交到本地暂存区、从版本库中删除文件等。同时还介绍了如何从暂存区恢复到工作文件、恢复最近一次提交过的状态,以及如何合并多个操作等。 ... [详细]
  • 本文介绍了在Ubuntu系统中清理残余配置文件和无用内容的方法,包括清理残余配置文件、清理下载缓存包、清理不再需要的包、清理无用的语言文件和清理无用的翻译内容。通过这些清理操作可以节省硬盘空间,提高系统的运行效率。 ... [详细]
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • 学习笔记(34):第三阶段4.2.6:SpringCloud Config配置中心的应用与原理第三阶段4.2.6SpringCloud Config配置中心的应用与原理
    立即学习:https:edu.csdn.netcourseplay29983432482?utm_sourceblogtoedu配置中心得核心逻辑springcloudconfi ... [详细]
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • imx6ull开发板驱动MT7601U无线网卡的方法和步骤详解
    本文详细介绍了在imx6ull开发板上驱动MT7601U无线网卡的方法和步骤。首先介绍了开发环境和硬件平台,然后说明了MT7601U驱动已经集成在linux内核的linux-4.x.x/drivers/net/wireless/mediatek/mt7601u文件中。接着介绍了移植mt7601u驱动的过程,包括编译内核和配置设备驱动。最后,列举了关键词和相关信息供读者参考。 ... [详细]
  • 本文介绍了Android 7的学习笔记总结,包括最新的移动架构视频、大厂安卓面试真题和项目实战源码讲义。同时还分享了开源的完整内容,并提醒读者在使用FileProvider适配时要注意不同模块的AndroidManfiest.xml中配置的xml文件名必须不同,否则会出现问题。 ... [详细]
  • Go GUIlxn/walk 学习3.菜单栏和工具栏的具体实现
    本文介绍了使用Go语言的GUI库lxn/walk实现菜单栏和工具栏的具体方法,包括消息窗口的产生、文件放置动作响应和提示框的应用。部分代码来自上一篇博客和lxn/walk官方示例。文章提供了学习GUI开发的实际案例和代码示例。 ... [详细]
  • web.py开发web 第八章 Formalchemy 服务端验证方法
    本文介绍了在web.py开发中使用Formalchemy进行服务端表单数据验证的方法。以User表单为例,详细说明了对各字段的验证要求,包括必填、长度限制、唯一性等。同时介绍了如何自定义验证方法来实现验证唯一性和两个密码是否相等的功能。该文提供了相关代码示例。 ... [详细]
  • 海马s5近光灯能否直接更换为H7?
    本文主要介绍了海马s5车型的近光灯是否可以直接更换为H7灯泡,并提供了完整的教程下载地址。此外,还详细讲解了DSP功能函数中的数据拷贝、数据填充和浮点数转换为定点数的相关内容。 ... [详细]
  • 超级简单加解密工具的方案和功能
    本文介绍了一个超级简单的加解密工具的方案和功能。该工具可以读取文件头,并根据特定长度进行加密,加密后将加密部分写入源文件。同时,该工具也支持解密操作。加密和解密过程是可逆的。本文还提到了一些相关的功能和使用方法,并给出了Python代码示例。 ... [详细]
  • 本文介绍了5个基本Linux命令行工具的现代化替代品,包括du、top和ncdu。这些替代品在功能上进行了改进,提高了可用性,并且适用于现代化系统。其中,ncdu是du的替代品,它提供了与du类似的结果,但在一个基于curses的交互式界面中,重点关注占用磁盘空间较多的目录。 ... [详细]
  • Spring框架《一》简介
    Spring框架《一》1.Spring概述1.1简介1.2Spring模板二、IOC容器和Bean1.IOC和DI简介2.三种通过类型获取bean3.给bean的属性赋值3.1依赖 ... [详细]
author-avatar
伤心怪人_234
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有