热门标签 | 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

 



推荐阅读
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • VSCode与Gitee集成:项目提交的高效实践
    本文介绍如何利用VSCode内置的Git工具将项目提交到Gitee,简化Git命令的使用,提升代码管理效率。同时分享一些常见的踩坑经验和解决方案。 ... [详细]
  • ASP.NET MVC中Area机制的实现与优化
    本文探讨了在ASP.NET MVC框架中,如何通过Area机制有效地组织和管理大规模应用程序的不同功能模块。通过合理的文件夹结构和命名规则,开发人员可以更高效地管理和扩展项目。 ... [详细]
  • 微软Exchange服务器遭遇2022年版“千年虫”漏洞
    微软Exchange服务器在新年伊始遭遇了一个类似于‘千年虫’的日期处理漏洞,导致邮件传输受阻。该问题主要影响配置了FIP-FS恶意软件引擎的Exchange 2016和2019版本。 ... [详细]
  • 如何配置Unturned服务器及其消息设置
    本文详细介绍了Unturned服务器的配置方法和消息设置技巧,帮助用户了解并优化服务器管理。同时,提供了关于云服务资源操作记录、远程登录设置以及文件传输的相关补充信息。 ... [详细]
  • 本文深入探讨了Linux系统中网卡绑定(bonding)的七种工作模式。网卡绑定技术通过将多个物理网卡组合成一个逻辑网卡,实现网络冗余、带宽聚合和负载均衡,在生产环境中广泛应用。文章详细介绍了每种模式的特点、适用场景及配置方法。 ... [详细]
  • 如何在PHPCMS V9中实现多站点功能并配置独立域名与动态URL
    本文介绍如何在PHPCMS V9中创建和管理多个站点,包括配置独立域名、设置动态URL,并确保各子站能够正常运行。我们将详细讲解从新建站点到最终配置路由的每一步骤。 ... [详细]
  • 本文详细分析了Hive在启动过程中遇到的权限拒绝错误,并提供了多种解决方案,包括调整文件权限、用户组设置以及环境变量配置等。 ... [详细]
  • MySQL缓存机制深度解析
    本文详细探讨了MySQL的缓存机制,包括主从复制、读写分离以及缓存同步策略等内容。通过理解这些概念和技术,读者可以更好地优化数据库性能。 ... [详细]
  • andr ... [详细]
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
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社区 版权所有