Git 详解,帮你突破瓶颈

#新建一个目录,就是新建一个文件夹

mkdir

#删除一个文件夹, rm -r src 删除src目录

rm -r

#切勿在Linux中尝试!删除电脑中全部文件!

rm -rf/

#移动文件, mv index.html src index.html 是我们要移动的文件, src 是目标文件夹,当然, 这样写,必须保证文件和目标文件夹在同一目录下

mv

#重新初始化终端/清屏

reset

#清屏

clear

#查看命令历史

history

#帮助

help

#退出

exit

#注释

4、Git配置


所有的配置文件,其实都保存在本地!

查看配置命令

#查看配置

git config -l

#查看系统config

git config --system --list

#查看当前用户(global)配置

git config --global --list

Git相关的配置文件:

1)、Git\etc\gitconfig :Git 安装目录下的 gitconfig --system 系统级

2)、C:\Users\Administrator\.gitconfig 只适用于当前登录用户的配置 --global 全局

5、设置用户名与邮箱(用户标识,必要)


当你安装Git后首先要做的事情是设置你的用户名称和e-mail地址。这是非常重要的,因为每次Git提交都会使用该信息。它被永远的嵌入到了你的提交中:

#名称

git config --global user.name “kuangshen”

#邮箱

git config --global user.email 24736743@qq.com

只需要做一次这个设置,如果你传递了–global 选项,因为Git将总是会使用该信息来处理你在系统中所做的一切操作。如果你希望在一个特定的项目中使用不同的名称或e-mail地址,你可以在该项目中运行该命令而不要–global选项。总之–global为全局配置,不加为某个项目的特定配置。

三、Git基本理论(重要)

=============

1、四个区域


  • 工作目录(Working Directory)

  • 就是你平时存放项目代码的地方

  • 暂存区 (Stage/Index)

  • 用于临时存放你的改动,事实上它只是一个文件,保存即将提交到文件列表信息

  • 资源库 (Repository或Git Directory) 本地仓库

  • 就是安全存放数据的位置,这里面有你提交到所有版本的数据。其中HEAD指向最新放入仓库的版本

  • 远程仓库 (Remote Directory)

  • 远程仓库,托管代码的服务器,可以简单的认为是你项目组中的一台电脑用于远程数据交换

2、本地目录结构


本地的三个区域确切的说应该是git仓库中HEAD指向的版本:

  • Directory:使用Git管理的一个目录,也就是一个仓库,包含我们的工作空间和Git的管理空间。

  • WorkSpace:需要通过Git进行版本控制的目录和文件,这些目录和文件组成了工作空间。

  • .git:存放Git管理信息的目录,初始化仓库的时候自动创建。

  • Index/Stage:暂存区,或者叫待提交更新区,在提交进入repo之前,我们可以把所有的更新放在暂存区。

  • Local Repo:本地仓库,一个存放在本地的版本库;HEAD会指向当前的开发分支(branch)。

  • Stash:隐藏,是一个工作状态保存栈,用于保存/恢复WorkSpace中的临时状态。


  • objects

存储对象的目录,本地仓库,git中对象分为三种:commit对象,tree对象(多叉树),blob对象;

Git从核心上来看不过是简单地存储键值对(key-value)(hashmap),大概结构如下: Key=sha-1(file header + file content) Value=压缩(file content)

Key是一个40位字符的校验和,前2位作为子目录,后38位作为文件名保存在子目录下

  • refs

存储指向branch(分支)的最近一次commit对象的指针,也就是commit对象的sha-1值(就是hash值,sha-1是一种散列算法),refs的目录下包括以下目录(git init后并没有remotes和stash,需要有从remote地址中pull code等交互性操作才会出现remotes目录,stash文件则是做了stash操作才会出现):

    • heads

是存储本地仓库每一个分支最近一次commit对象的sha-1值

  • remotes

存储最近一次push到远程仓库的commit对象的sha-1值

  • tags

存储历史版本的最后一次commit对象的sha-1值

(要与branch区分开来,tags本质就是branch,与branch不同的是tag是不会有改动的,是历史版本记录)

  • stash

存储藏匿处(就是GitExtentsions中的stash操作)的对象sha-1值


Git仓库.git文件夹目录介绍

3、工作流程


git的工作流程一般是这样的:

1、在工作目录中添加、修改文件;

2、将需要进行版本管理的文件放入暂存区域;

3、将暂存区域的文件提交到git仓库。

因此,git管理的文件有三种状态:已修改(modified),已暂存(staged),已提交(committed)

四、Git项目搭建

=========

4.1、创建工作目录与常用指令


工作目录(WorkSpace)一般就是你希望Git帮助你管理的文件夹,可以是你项目的目录,也可以是一个空目录,建议不要有中文。

日常使用只要记住下图6个命令:

4.2、本地仓库搭建


创建本地仓库的方法有两种:

1、创建全新的仓库

  • 创建全新的仓库,需要用GIT管理的项目的根目录执行:

在当前目录新建一个Git代码库

$ git init

  • 执行后可以看到,仅仅在项目目录多出了一个.git目录,关于版本等的所有信息都在这个目录里面。

2、克隆远程仓库

  • 克隆远程目录,由于是将远程服务器上的仓库完全镜像一份至本地!

克隆一个项目和它的整个代码历史(版本信息)

https://gitee.com/kuangstudy/openclass.git

$ git clone [url]

  • 去 gitee 或者 github 上克隆一个测试!

五、GIT基本操作

=========

1、文件的状态


参考:Git中文件的4种状态Untracked、Unmodify、Modified、Staged - 嘿十三 - 博客园

版本控制就是对文件的版本控制,要对文件进行修改、提交等操作,首先要知道文件当前在什么状态,不然可能会提交了现在还不想提交的文件,或者要提交的文件没提交上。

  • 未跟踪状态 Untracked

  • Untracked

  • 未跟踪, 此文件在文件夹中, 但并没有加入到git库, 不参与版本控制. 通过git add 状态变为Staged

  • 跟踪状态 Tracked

  • Unmodified

  • 文件已经入库, 未修改, 即版本库中的文件快照内容与文件夹中完全一致. 这种类型的文件有两种去处, 如果它被修改, 而变为Modified. 如果使用git rm移出版本库, 则成为Untracked文件

  • Modified

  • 文件已修改, 仅仅是修改, 并没有进行其他的操作. 这个文件也有两个去处, 通过git add可进入暂存staged状态, 使用git checkout 则丢弃修改过, 返回到unmodified状态, 这个git checkout即从库中取出文件, 覆盖当前修改 !

  • Staged

  • 暂存状态. 执行git commit则将修改同步到库中, 这时库中的文件和本地文件又变为一致, 文件为Unmodified状态. 执行git reset HEAD filename取消暂存, 文件状态为Modified

2、查看文件状态


上面说文件有4种状态,通过如下命令可以查看到文件的状态:

#查看指定文件状态

git status [filename]

#查看所有文件状态

git status

#添加所有文件到暂存区。后面有点.

git add .

#提交暂存区中的内容到本地仓库 -m 提交信息

git commit -m “消息内容”

3、忽略文件


有些时候我们不想把某些文件纳入版本控制中,比如数据库文件,临时文件,设计文件等

在主目录下建立".gitignore"文件,此文件有如下规则:

  1. 忽略文件中的空行或以井号(#)开始的行将会被忽略。

  2. 可以使用Linux通配符。例如:星号(*)代表任意多个字符,问号(?)代表一个字符,方括号([abc])代表可选字符范围,大括号({string1,string2,…})代表可选的字符串等。

  3. 如果名称的最前面有一个感叹号(!),表示例外规则,将不被忽略。

  4. 如果名称的最前面是一个路径分隔符(/),表示要忽略的文件在此目录下,而子目录中的文件不忽略。

  5. 如果名称的最后面是一个路径分隔符(/),表示要忽略的是此目录下该名称的子目录,而非文件(默认文件或目录都忽略)。

#为注释

#忽略所有 .txt结尾的文件,这样的话上传就不会被选中!

*.txt

#但lib.txt除外

!lib.txt

#仅忽略项目根目录下的TODO文件,不包括其它目录temp

/temp

#忽略build/目录下的所有文件

build/

#会忽略 doc/notes.txt 但不包括 doc/server/arch.txt

doc/*.txt

4、常用命令


1)仓库

在当前目录新建一个Git代码库

$ git init

新建一个目录,将其初始化为Git代码库

$ git init [project-name]

下载一个项目和它的整个代码历史

$ git clone [url]

2)配置

显示当前的Git配置

$ git config --list

编辑Git配置文件

$ git config -e [–global]

设置提交代码时的用户信息

$ git config [–global] user.name “[name]”

$ git config [–global] user.email “[email address]”

3)增加/删除文件

添加指定文件到暂存区

$ git add [file1] [file2] …

添加指定目录到暂存区,包括子目录

$ git add [dir]

添加当前目录的所有文件到暂存区

$ git add .

添加每个变化前,都会要求确认

对于同一个文件的多处变化,可以实现分次提交

$ git add -p

删除工作区文件,并且将这次删除放入暂存区

$ git rm [file1] [file2] …

停止追踪指定文件,但该文件会保留在工作区

$ git rm --cached [file]

改名文件,并且将这个改名放入暂存区

$ git mv [file-original] [file-renamed]

4)代码提交

提交暂存区到仓库区

$ git commit -m [message]

提交暂存区的指定文件到仓库区

$ git commit [file1] [file2] … -m [message]

提交工作区自上次commit之后的变化,直接到仓库区

$ git commit -a

提交时显示所有diff信息

$ git commit -v

使用一次新的commit,替代上一次提交

如果代码没有任何新变化,则用来改写上一次commit的提交信息

$ git commit --amend -m [message]

重做上一次commit,并包括指定文件的新变化

$ git commit --amend [file1] [file2] …

5)分支

列出所有本地分支

$ git branch

列出所有远程分支

$ git branch -r

列出所有本地分支和远程分支

$ git branch -a

新建一个分支,但依然停留在当前分支

$ git branch [branch-name]

新建一个分支,并切换到该分支

$ git checkout -b [branch]

新建一个分支,指向指定commit

$ git branch [branch] [commit]

新建一个分支,与指定的远程分支建立追踪关系

$ git branch --track [branch] [remote-branch]

切换到指定分支,并更新工作区

$ git checkout [branch-name]

切换到上一个分支

$ git checkout -

建立追踪关系,在现有分支与指定的远程分支之间

$ git branch --set-upstream [branch] [remote-branch]

合并指定分支到当前分支

$ git merge [branch]

选择一个commit,合并进当前分支

$ git cherry-pick [commit]

删除分支

$ git branch -d [branch-name]

删除远程分支

$ git push origin --delete [branch-name]

$ git branch -dr [remote/branch]

6)标签

列出所有tag

$ git tag

新建一个tag在当前commit

$ git tag [tag]

新建一个tag在指定commit

$ git tag [tag] [commit]

删除本地tag

$ git tag -d [tag]

删除远程tag

$ git push origin :refs/tags/[tagName]

查看tag信息

$ git show [tag]

小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Java工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Java开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频

如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Java)
img

复习的面试资料

这些面试全部出自大厂面试真题和面试合集当中,小编已经为大家整理完毕(PDF版)

  • 第一部分:Java基础-中级-高级

image

  • 第二部分:开源框架(SSM:Spring+SpringMVC+MyBatis)

image

  • 第三部分:性能调优(JVM+MySQL+Tomcat)

image

  • 第四部分:分布式(限流:ZK+Nginx;缓存:Redis+MongoDB+Memcached;通讯:MQ+kafka)

image

  • 第五部分:微服务(SpringBoot+SpringCloud+Dubbo)

image

  • 第六部分:其他:并发编程+设计模式+数据结构与算法+网络

image

进阶学习笔记pdf

  • Java架构进阶之架构筑基篇(Java基础+并发编程+JVM+MySQL+Tomcat+网络+数据结构与算法

image

  • Java架构进阶之开源框架篇(设计模式+Spring+SpringMVC+MyBatis

image

image

image

  • Java架构进阶之分布式架构篇 (限流(ZK/Nginx)+缓存(Redis/MongoDB/Memcached)+通讯(MQ/kafka)

image

image

image

  • Java架构进阶之微服务架构篇(RPC+SpringBoot+SpringCloud+Dubbo+K8s)

image

image

MQ+kafka)**

[外链图片转存中…(img-gN5KveCq-1711133484713)]

  • 第五部分:微服务(SpringBoot+SpringCloud+Dubbo)

[外链图片转存中…(img-XwG5ing5-1711133484713)]

  • 第六部分:其他:并发编程+设计模式+数据结构与算法+网络

[外链图片转存中…(img-0jSGsZnN-1711133484713)]

进阶学习笔记pdf

  • Java架构进阶之架构筑基篇(Java基础+并发编程+JVM+MySQL+Tomcat+网络+数据结构与算法

[外链图片转存中…(img-gmI3bXBH-1711133484714)]

  • Java架构进阶之开源框架篇(设计模式+Spring+SpringMVC+MyBatis

[外链图片转存中…(img-aZUwbkTF-1711133484714)]

[外链图片转存中…(img-czw0CbLz-1711133484714)]

[外链图片转存中…(img-OMgY5kRL-1711133484715)]

  • Java架构进阶之分布式架构篇 (限流(ZK/Nginx)+缓存(Redis/MongoDB/Memcached)+通讯(MQ/kafka)

[外链图片转存中…(img-XklrQeJD-1711133484715)]

[外链图片转存中…(img-xNDlPuq9-1711133484715)]

[外链图片转存中…(img-texVmgKH-1711133484716)]

  • Java架构进阶之微服务架构篇(RPC+SpringBoot+SpringCloud+Dubbo+K8s)

[外链图片转存中…(img-bPn3nDgm-1711133484716)]

[外链图片转存中…(img-GZeDCH3Z-1711133484716)]

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

  • 9
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值