Git 小白入门到进阶—(基本概念和常用命令)

news2024/9/25 21:28:53

一.了解 Git 基本概念和常用命令的作用 (理论)

基本概念

1、工作区
包含.git文件夹的目录,主要用存放开发的代码
2、仓库
分为本地仓库和远程仓库,本地仓库是自己电脑上的git仓库(.git文件夹);远程仓库是在远程服务器上的git仓库git文件夹无需我们进行操作,只需要执行相关命令即可。
3、暂存区(索引)
git文件夹中有很多文件,其中有一个index文件就是暂存区
4、已修改(modifed):修改了文件,但还没将修改的结果放到暂存区
5、已暂存(staged):对已修改文件的当前版本做了标记暂时保存,会包含在下次提交的列表中3、6、已提交(committed):文件已经安全地保存在本地的git仓库中
7、分支和标签
①、分支
git 有一个主分支- master 分支(包含了最稳定的版本),通常来说,一个分支用于一个新功能的开发,一旦新功能开发完成,就将这个分支合并到 master 上,然后删除这个分支。每个分支都可由 HEAD 指示,HEAD是一个指针,它永远指向分支中的最新提交内容。
②、标签
标签和分支很相似,不同的地方在于标签是不变动的。标签是一种没人去修改的分支。一旦为某个特定提交操作创造了一个标签,即使有新的提交操作,它也不会更新,开发者会给产品的发行版本创建标签(也是我们常说的打tag)。

Git 和 GitHub 的区别和关系如下:

1、Git 是工具,而 GitHub 是平台。
2、我们可以用 Git 之外的版本控制系统(比如 SVN)来向 GitHub 提交代码;同样可以用 Git 将代码提交到 GitHub之外的其他代码托管平台(比如企业级代码托管平台 GitLab)上。SVN 和 Git 是同类的工具,两者的用法很相似。但目前 Git 相对更主流一些,因此只学习 Git 足够了。 

工作流程

1、从远程仓库中克隆代码到本地仓库
2、本地仓库中分支进行代码修改
3、在提交前先将代码提交到暂存区
4、提交到本地仓库本
5、修改完成后,将代码push到远程仓库(之后的每次养成先pull再push的习惯)

二.能够使用 Git 命令来管理和提交项目代码 (实践)

1、创建远程仓库
在 GitHub 上创建一个新的远程仓库,获取仓库的 URL 地址
2、从本地仓库提交代码到远程仓库
①、在当前工作目录中初始化新仓库

git init

添加文件到本地暂存区中

git add

提交暂存区到本地仓库

git commit-m "提交说明"

连接远程仓库

git remote add origin 仓库地

提交之前先 pull

git pull origin 远程分支名:本地分支名

如果远程分支是与当前分支合并,则冒号后面的部分可以省略  git pull origin 分支名
提交到远程仓库

git push origin 本地分支名:远程分支名

如果本地分支名与远程分支名相同,则可以省略冒号 git push origin 分支名
强制推送可以使用 --force 参数

git push--force origin 分支名

3、从现有仓库克隆

git clone url
Git支持多种协议,默认的git://使用ssh,但也可使用https等其他协议。url地址可以为https:/lgithub/xx/xx/xx.git

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

git add .

注意 . 前有空格

提交暂存区到本地仓库

git commit-m "提交说明"

提交之前先 pull

git pull origin 远程分支名:本地分支名

提交到远程仓库

git push origin 本地分支名:远程分支名

显示当前的Git配置

git config --list

编辑Git配置文件

git config-e[--global]

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

git config--global user.name“用户名
git config--global user.email“郎箱地址

查看当前分支

git branch

查看仓库当前的状态,显示变更文件信息

git status

查看历史提交记录  git log

显示当前分支的最近几次提交 git reflog

下载远程仓库的所有变动

git fetch

下载特定远程仓库的所有变动

git fetch[远端仓库名]

下载远程仓库对应分支的变动

git fetch[远端仓库名][远端分支名称]

下载远程仓库对应分支的变动到本地分支

git fetch[远端仓库名][远端分支名称]:[本地分支名称]

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1705822.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

一些硬件知识【九】

STM32CUBEMX配置教程(六)高级定时器单通道输出互补PWM波(带死区和刹车)_高级定时器死区刹车怎么与电机模块连接?-CSDN博客 MOS选型关键参数: 额定电压,额定电流,导通电阻,阀值电压…

如何通过中间人攻击嗅探SIM卡的流量通信

写在前面的话 这篇文章我将介绍如何制作中间人(MitM)设置来嗅探SIM卡和后端服务器之间的流量。虽然这不是一项新的研究,但我希望这将帮助一些没有电信基础的人学习移动数据嗅探和虚假基站的知识。但是我只会介绍使用2G和GPRS的SIM卡的方案。…

防止特权升级攻击的有效策略

防止特权升级攻击的有效策略 特权升级攻击是一种通过利用操作系统或应用程序中的编程错误、漏洞、设计缺陷、配置错误或访问控制缺陷,获得对原本应该被限制访问的资源进行未授权访问的行为。这种攻击方式可能导致攻击者获取敏感数据、安装恶意软件并发动其他网络攻…

揭秘网络编程:同步与异步IO模型的实战演练

摘要 ​ 在网络编程领域,同步(Synchronous)、异步(Asynchronous)、阻塞(Blocking)与非阻塞(Non-blocking)IO模型是核心概念。尽管这些概念在多篇文章中被广泛讨论,它们的抽象性使得彻底理解并非易事。本文旨在通过具体的实验案例,将这些抽象…

Python + adb 实现打电话功能

前言 其实很多年前写过一篇python打电话的功能,链接如下: Python twilio 实现打电话和发短信功能_自动发短信代码-CSDN博客 今天由于工作需要,又用python写了个关于打电话的小工具,主要是通过ADB方式实现的 实现过程 1.先利用…

抖店重磅新规!保证金下调,一张营业执照能开多个店铺了!

哈喽~我是月月 抖音平台为助力小商家实现开店低成本,轻负担,高收益的模式 在5月30日正式实施了两个政策:保证金下调,一证多开 政策一:保证金下调 这次政策,涉及的类目优惠包含了,平台近70%的…

一文详解SpringBoot的自定义starter

目录 一、SpringBoot 二、自定义starter 三、SpringBoot的自定义starter 一、SpringBoot Spring Boot是一个开源的Java框架,由Pivotal团队(现为VMware的一部分)于2013年推出,旨在简化Spring应用程序的创建和部署过程。它基于S…

布隆过滤器-详解及使用

一、什么是布隆过滤器 1、简介 布隆过滤器是一个很长的二进制向量和一系列随机映射函数。可以用于检索一个元素是否在一个集合中。。理解为SET集合。 布隆过滤器其内部维护了一个全为 0 的 bit 数组,需要说明的是,布隆过滤器有一个误判的概念&#xf…

【全开源】宇鹿家政系统(FastAdmin+ThinkPHP+原生微信小程序)

:助力家政行业数字化升级 一、引言:家政服务的新篇章 随着移动互联网的普及和人们生活水平的提高,家政服务的需求日益增长。为了满足这一市场需求,并推动家政行业的数字化升级,我们特别推出了家政小程序系统源码。这…

代码随想录算法训练营第四十二天|62.不同路径、63. 不同路径 II

62.不同路径 文档讲解:代码随想录 题目链接:. - 力扣(LeetCode) 记录每个格子的状态 二维矩阵-->二维dp数组 dp数组 题目是要求到达最后一个格子有多少种路径 所以dp[i,j]: 到达第(i,j)个格子有多少种路径 递推公式 到达一…

vue+three.js实现3d系统的搭建

1.首先node.js是12.22版本的,安装three.js可以参考这篇文章 直接用Threejs入门-安装教程_安装three.js-CSDN博客 直接在终端安装three.js即可 npm install --save three 在相同目录下安装vite构建工具 npm install --save-dev vite 在项目里面看package.json中…

1688 API接口介绍:开启您的电商新篇章

什么是1688 API接口? API(Application Programming Interface,应用程序编程接口)是一组协议和工具,用于定义不同的软件应用程序如何彼此交互。1688 API接口则是1688平台为商家提供的一套接口规范,允许商家…

浏览器提示网站不安全怎么办?有什么解决办法吗?

当你在浏览器中访问一个网站时,如果看到提示说该网站不安全,这通常是由于网站没有使用SSL证书或者SSL证书存在问题。SSL证书在这里扮演着非常关键的角色,下面我会详细解释它的作用以及如何解决这类不安全提示。 SSL证书的作用: 1…

德邦快递和德邦物流运费标准哪个更划算?怎样才能便宜的寄大件快递?

在寄大件包裹快递时,我们一般都知道选择德邦,那么德邦快递和德邦物流的收费标准哪个更划算呢?下面,让我们一起来了解德邦快递和德邦物流的收费标准,以及如何根据实际情况做出最佳选择。 首先了解快递费用构成 快递费用…

OpenHarmony 入门——初识JS/ArkTS 侧的“JNI” NAPI(一)

引言 在Android中Java可以通过JNI 与C/C 通信,而在OpenHarmony 中前段语言目前是ETS,那么OpenHarmony中的 “JNI” 角色是什么呢? 一、NAPI概述 NAPI全称Native Application Programming Interface(最新版的文档已经改为Node-A…

java医院管理系统源码(springboot+vue+mysql)

风定落花生,歌声逐流水,大家好我是风歌,混迹在java圈的辛苦码农。今天要和大家聊的是一款基于springboot的医院管理系统。项目源码以及部署相关请联系风歌,文末附上联系信息 。 项目简介: 医院管理系统的主要使用者分…

【IDEA】Redis可视化神器

在开发过程中,为了方便地管理 Redis 数据库,我们可能会使用一些数据库可视化插件。这些插件通常可以帮助你在 IDE 中直观地查看和管理 Redis 数据库,包括查看键值对、执行命令、监视数据库活动等。 IDEA作为IDE界的Jenkins,本身自…

软件项目管理 - 作业集合

软件项目管理 - 作业集合 作业一 1、项目与日常运作的主要区别有哪些? 项目:为提供一项独特产品、服务或成果所做的临时性努力 运作:连续不断周而复始的活动 项目是一次性的,日常运作是重复进行的; 项目是以目标为导…

Spring AOP基于动态代理的实现的 AOP

目录 代理什么是代理代理模式 静态代理动态代理JDK动态代理CGLIB动态代理Spring AOP使用的是哪种代理? 代理 什么是代理 生活中的代理 房产中介 : 房屋进行租赁时,卖方会把房子授权给中介,由中介代理带客户看房,商谈…

线段树例题

目录 1.Sequence 2.Peach Conference 3.Permutation Subsequence 1.Sequence 题目描述: Given an array a consisting of n integers, on which you are to perform m operations of two types. 1.Given two integers x,y, replace the number of index x with n…