首页 > 其他分享 >Git学习笔记1 | Git简介、安装和配置

Git学习笔记1 | Git简介、安装和配置

时间:2024-03-07 23:33:39浏览次数:18  
标签:文件 Git 项目 仓库 简介 笔记 文件夹 git

Git学习笔记1

一、Git 简介

image-20240307231010579

Git 官网:https://git-scm.com/

更详细的笔记可参考文章:https://blog.csdn.net/Unirithe/article/details/122428756

Git是一个开源的分布式版本控制系统

(1)作用:有效、高速地处理从很小到非常大的项目版本管理

(2)起源:[Linus Torvalds](https://baike.baidu.com/item/Linus Torvalds/9336769) (Linux之父)为了帮助管理Linux内核开发而开发的一个开放源码的版本控制软件。

参考:https://baike.baidu.com/item/GIT/12647237

1.1 Git 的功能与特点

1、从服务器上克隆完整的 Git 仓库(包括代码和版本信息)到单机上

如:将GitHub 、Gitee上的项目下载到本地,如果本机上有Git环境的话,就可以看到这个Git项目的所有版本信息。

2、有助于开发者独立开发项目

如:在自己的机器上根据不同的开发目的,创建分支,修改代码,提交代码,合并分支等操作。

3、有助于团队开发

如:把服务器上最新版的代码fetch下来,然后跟自己的主分支合并,从而生成补丁(patch),把补丁发送给主开发者。

看主开发者的反馈,如果主开发者发现两个一般开发者之间有冲突(他们之间可以合作解决的冲突),就会要求他们先解决冲突,然后再由其中一个人提交。如果主开发者可以自己解决,或者没有冲突,就通过。

4、有助于非开发人员管理项目

如:从主开发者的角度(假设主开发者不用开发代码)看,git 有以下功能:

  • 查看邮件或者通过其它方式查看其他开发者的提交状态。
  • 打上补丁,解决冲突(可以自己解决,也可以要求开发者之间解决以后再重新提交,如果是开源项目,还要决定哪些补丁有用,哪些不用)。
  • 向公共服务器提交结果,然后通知所有开发人员。

1.2 Git 的工作流程

阅读完这一小节你将学到:

  • Git大概是怎样存在的
  • Git的工作流程是怎样的
  • 如何在自己电脑上使用 Git 管理本地的项目

在介绍工作流程前,我们先了解一下Git项目是怎样存在的

image-20240307231057347

如上图所示,.idea 表明当前文件夹是一个 IDEA项目,而 .idea里面则存储了一些关于这个项目的配置,有了这个文件夹,只要把这个项目打包,发送给其他人,他们同样能用IDEA打开这个项目。

Git 也是差不多的原理,可以看到这里面有个隐藏的文件夹 .git ,其实我这是一个 Git 项目,每一个Git项目都会有一个隐藏的 .git用于管理git项目的相关信息。

所以,可以把 Git 简单理解成一个更好管理文件夹的工具。而管理的文件信息就在被管理的项目里。

如果我把这个项目打包发给其他人,那人的电脑里只要有 Git 环境,那同样能对这个项目进行版本控制,就跟 IDEA的原理一样,即:有一个专门的文件夹存储项目的信息。

接下来是 Git 的工作流程:

image-20240307231129702

这个工作流程十分关键,这里需要记住,从工作区提交文件到仓库,必须经过暂存区

仓库是最重要的,当前项目的重要文件应该保存到仓库里面。

这里的工作区可以理解为项目文件夹,而暂存区的相关概念,我们在入门阶段可以暂时不管。

接下来举个例子,如果要在当前的Git项目(文件夹)里添加一个文件,该如何操作?

可以直接新建吗? 当然可以~

image-20240307231610486

或者是直接拖文件进来? 也是可以的。

说白了就跟普通的文件夹一样,但是,有一个问题,如果像原来一样管理这个文件夹,那么在 .git文件夹里,就是记录当前项目的git文件夹,没有发生任何改变,所以本质上,git仓库是没有发生变化的。

根据之前的流程图,可以发现,发生变化的只是工作区,我们这个文件夹就相当于一个工作区。要想提交到仓库

那当我创建一个文件后,该怎样把它添加到 git 的仓库呢?

(1)add 命令 先添加到暂存区

(2)commit 命令,提交到 本地 / 远程仓库

只要通过这两个命令,就可以把文件添加到 Git的仓库里面了,同时在添加后 Git 会产生一个新的版本。

每一次的commit都会产生新的版本,而我们可以在不同版本之间进行切换。

1.3 Git 常用命令

命令 作用描述
clone 克隆,从远程仓库中克隆代码到本地仓库
checkout 检出,从本地仓库中检出一个仓库分支然后进行修订
add 添加,在提交前先将代码提交到暂存区
commit 提交,提交到本地仓库。本地仓库中保存修改的各个历史版本
fetch 抓取,从远程库抓取到本地仓库,不进行任何的合并操作
pull 拉取,从远程库拉到本地库,自动进行合并(merge),然后放到工作区,相当于 fetch + merge
push 推送,修改完成后,需要和团队成员共享代码时,将代码推送到远程仓库

这些命令中最常用的就是 add、commit、push 和 pull 这四个,记不住没关系,因为在实际应用中,很少会有手动去输入这些命令的情况,一般都是直接使用集成Git的工具或者插件进行Git的相关操作。

如:使用 IDEA 操作 Git 项目

image-20240307231642144

这些都是可视化的操作,只要用鼠标点一点就能控制Git项目。

二、Git 的安装与配置

2.1 Git 下载与安装

Git 官方下载:https://git-scm.com/download/win

image-20240307231726462

在安装时,会要求选择两个工具,Git Bash 和 Git GUI。

Git Bash:Git 提供的命令行工具,支持Linux命令,必选

Git GUI:Git 提供的图形界面工具,不太好用,可以不选

2.2 配置本机git的邮箱和名称

安装 Git 后首先要做的就是设置个人的用户名称和email地址,就跟注册QQ账号一样。

不过建议最好和gitee(一个基于 Git 的代码托管和研发协作平台)的账号一致,这样就可以直接将本地项目上传到gitee码云。github也可以,但是github经常进不去,不推荐使用

所以可以先注册一个 gitee账号,然后在进行git邮箱的配置:gitee 官网:https://gitee.com/

git打开的三种方式:

第一种:直接在系统下方搜索 git bash

image-20240307231804643

第二种:在任何一个文件夹里右键,(Win11的话需点击更多选项),此时可选择打开 git bash

image-20240307231826124

第三种:将绝对路径下的工具快捷方式到桌面

git快捷方式的默认位置在:C:\ProgramData\Microsoft\Windows\Start Menu\Programs\Git

image-20240307231839648

这样的话可以在桌面打开git bash。

三种打开方式依个人喜好而定。

接下来在 git bash 绑定跟 gitee 账号相同的邮箱和名称

git config --global user.name ccuni

git config --global user.email [email protected]

绑定过后可以查询绑定的结果,每行命令的最后一个参数不填则为查询结果,如下图:

image-20240307231901523

2.3 使用指令别名,便于查看日志

alias命令可以给一个指令起别名,这样可以很方便的实现原本一长串的命令。

比如在Java里输出一个Hello,World的代码是:

System.out.println("Hello,World");

看起来比较麻烦,假设直接用sout来表示这个输出的方法,那么输出的方式就变成了

public void sout(String s){
     System.out.println(s);   
}
sout("Hello,World");
// 下次还能直接调用sout方法输出一些信息

看起来舒服多了对把,所以起别名还是挺有用的。

接下来在git bash里给命令起别名

1)创建环境变量的文件(跟在Linux里配置JDK环境变量是一样的)

touch ~/.bashrc

2)编辑环境变量文件 (git bash 支持使用 vim 命令)

vim ~/.bashrc

将配置的别名内容粘贴进去:

# 用于输出git提交日志
alias git-log='git log --pretty=oneline --all --graph --abbrev-commit'

# 用于输出当前目录所有文件及基本信息
alias ll='ls -al'

然后保存退出,和Linux一样,先 ESC 然后再 冒号: ,输入wq ,回车

3)使环境变量生效

source ~/.bashrc

配置过后就可以使用两个别名命令: git-logll

比如使用 ll 命令查看当前目录所有文件和基本信息

image-20240307232011639

注:当前位置是由打开``git bash的方式决定的,如果是在桌面打开的,那默认就在桌面,如果是在某个文件夹,那默认就在那个文件夹,问题不大,这个跟 Linux终端是一样的,可以输入 pwd` 查看当前的文件位置。

三、Git 操作介绍与实践

接下来的实践比较枯燥,但只要跟着做一遍的话,就能提升对git的理解。

3.1 获取本地仓库

使用Git对代码进行版本控制前首先需要获得的本地仓库,实现步骤如下:

第一步,在电脑的任意位置创建一个空目录(比如test-git)作为本地的Git仓库

第二步,进入创建的目录,右键鼠标打开Git Bash窗口

第三步,执行 git init 命令

第四步,如果创建成功后可以在文件夹下看到隐藏的.git目录

image-20240307232218650

3.2 Git 基础命令

image-20240307232517034

Git工作目录下对于文件的修改(增加、删除、更新)会存在几个状态,这些修改的状态会随着我们执行Git的命令而发生变化。

git add 工作区 -> 暂存区

git commoit 暂存区 -> 本地仓库

接下来是常用命令的格式与作用:

命令 标准格式 作用描述
status git status 查看修改的状态(暂存区、工作区)
add git add 单个文件名或通配符 添加工作区一个或多个文件的修改到暂存区
commit git commit -m "注释内容" 提交暂存区内容到本地仓库的当前分支
log git log [options] 查看提交记录可添加的[options]参数有-all 显示所有分支–pretty=oneline 将提交信息显示为一行–abbrev-commit 使得输出的commit Id 更简短–graph 以图的形式显示(多个参数以空格隔开)
reset git reset --hard commitID 版本回退(commitID可以使用 git log 命令查看)
reflog git reflog 查看已经删除的记录

3.3 设置 git 忽略的文件

有些文件无需纳入Git的管理,也不希望它们总出现在未跟踪文件列表。

通常都是些自动生成的文件,比如:日志文件、编译过程中创建的临时文件等。

在这种情况下,我们可以在工作目录中创建一个名为``.gitignore`的文件(文件名固定),列出要忽略的文件模式。

标签:文件,Git,项目,仓库,简介,笔记,文件夹,git
From: https://www.cnblogs.com/uni1024/p/18060038

相关文章

  • Strapi的使用笔记
    Strapi使用安装与使用我的电脑配置信息(93条消息)strapi安装指南_微雨即至的博客-CSDN博客安装参照node版本最好14node-vv14.21.3npm貌似必须在6以上npm-v6.14.18yarn-v1.22.19安装strapinpm方法(二选一)npminstallstrapi-g会安装最新的。(我使用这......
  • 标书专员工作个人简介
    个人简历个人信息姓名:[孙文杰]性别:[男]出生年月:[2000.09.15]联系电话:[17777828775]电子邮箱:[[email protected]]教育背景[会计],[北京邮电大学世纪学院],[2017-2021年]工作经历1.北京振威保安服务有限公司]职位:标书专员工作时间:[2021.6]-[至今]标书撰写与编辑:独立撰写并编......
  • JavaWeb之Java Servlet学习笔记
    JavaWeb学习笔记,主要是讲JavaServle,很适合Java开发网站的入门学习。(以课程进度为目录)第四周Web课.jsp中删除共性代码(html、body)————.java文件能相对的简洁taglib指令(标签库)动作元素action——element:包含include动态包含:在运行时才引入文件,代码也会动态引入,时间和......
  • Java基础 语法笔记
    大二学习Java语法时,上课写的部分笔记,可能并不完整,仅用以作纪念。数组、集合、字符串(第六课)目录数组、集合、字符串(第六课)数组集合类Collection接口:泛型:List:ArrayList:LinkedList类SetHashSet类TreeSet类MapLterator接口Vector类Collections类查找、替换操作复制StringtoString()......
  • vue3笔记 ref标签 04
    储存标记中的内容<template><divclass="about"><h1ref="Holly">你好</h1><button@click="hhh">点击输出上述h1</button></div></template><scriptlang="ts"setup>i......
  • 后缀数组学习笔记
    后缀数组学习笔记定义所谓后缀,指的是对于一个字符串\(s\),如果它的下标从\(1\)到\(n\),那么对于\(s\)的一个后缀\(i=s[i\dotsn]\)。所谓后缀数组sa[],就是按照这些后缀的字典序排序后得到的数组。更具体的,后缀数组sa[i]中存储的是字符串\(s\)中排名为\(i\)的后缀的......
  • 虚树学习笔记
    虚树学习笔记定义虚树指的是不同于原树(我称之为实树)的重构树,使得在同样能够求解的情况下,整棵树的节点数更少,从而使得在存在多次询问时,一些复杂度关于树的节点数的树上算法能够在时限内求解。常用场景一般来说,虚树的使用场景比较单一,常见于在实树上存在一些特殊节点,并且答案与......
  • 线性基学习笔记
    线性基学习笔记定义线性空间\(V\)内的一个极大线性无关组是\(V\)的一组hamel基或线性基,简称基。以上内容是OIWIKI中提及的定义。更具体一点来说,对于一个向量组\(v\),如果满足对于任意的取值,使\(\sum_{i=1}^n\alpha_iv_i\ne0\)(\(\alpha\)是常数),即不回到原点,那......
  • 网络流学习笔记
    网络流学习笔记本来是不想写的,因为不想在里面博客插入图片,但是发现网络流似乎可以牵扯出许多不为人知的图论内容,因此特此写一篇博客铺路。前言网络流是一种说难也不难,说简单也不简单的结构。难就难在对于一道题来说,我们难以分辨需要用到什么算法,怎么建图,因此,我们只能多做多练,积......
  • 基环树学习笔记
    基环树学习笔记定义基环树指的是一张有\(n\)个节点和\(n\)条边的图,如果不保证连通的话,那么整张图是一张基环树森林。并且如果将环上的任意一条边去除,那么整棵基环树会成为一棵普通的树。分类基环树有以下几种特殊情况,也是题目中较多出现的。基环内向树指的是在一棵有向......