Git介绍与常用命令总结

Git介绍与其常用命令总结

  • 1、Git介绍
  • 2、Git的使用
  • 3、Git常用命令
    • 3.1 初始化仓库
    • 3.2 克隆仓库
    • 3.3 配置用户信息
    • 3.4 提交代码(Commit)
    • 3.5 推送代码(Push)
    • 3.6 拉取代码(Pull)
    • 3.7 分支(Branch)
    • 3.8 远程仓库(Remote)
    • 3.9 撤销回退本地改动
    • 3.10 更新本地仓库与远程仓库

1、Git介绍

Git是一种分布式版本控制系统,用于跟踪文件的变化并协作开发项目。它由Linus Torvalds在2005年创建,主要用于Linux内核的开发,但现在已经成为许多项目的标准版本控制系统。

关于Git的一些关键概念和基本原理如下:

  • 版本控制: Git跟踪项目文件的变化,以便在不同的时间点恢复、比较或合并这些变化。这使得团队能够协作,同时保留项目历史记录。

  • 分布式系统: 每个协作者都拥有完整的代码仓库,包括完整的版本历史。这使得在没有网络连接的情况下也能够继续工作,并且使得协作更加灵活。

  • 仓库(Repository): Git仓库是包含项目文件和元数据的目录。它包括项目的完整历史记录和所有分支。

  • 工作区(Working Directory):工作区是包含项目文件的目录,可以进行修改和编辑。这是你实际工作的地方。

  • 暂存区(Staging Area):暂存区是一个临时区域,用于存储准备提交的文件。在将文件提交到版本库之前,你需要将它们添加到暂存区。

  • 提交(Commit): 提交是将文件的变化保存到版本库的操作。每个提交都有一个唯一的标识符,称为SHA-1哈希。

  • 分支(Branch):分支是项目的不同线条,每个分支代表一个独立的开发路径。分支可以合并,以将不同的工作合并到一起。

  • 远程仓库(Remote Repository):远程仓库是存储在网络上的项目的镜像,通常是团队共享和协作的中心。

  • 克隆(Clone):克隆是获取远程仓库的拷贝,可以在本地进行开发。

  • 推送(Push):推送是将本地提交上传到远程仓库的操作。

  • 拉取(Pull):拉取是将远程仓库的更新同步到本地仓库的操作。

在这里插入图片描述

Git提供了强大的工具,使团队能够高效地合作,跟踪项目的演变,并处理各种开发场景中的复杂性。通过这些概念和命令,开发者可以更好地管理项目的版本历史,减少冲突,追踪问题,并实现高效的代码协作。

通过Git,开发者可以很轻松地将项目代码推送到Github、Gitee、云效codeup等代码仓库平台,并进行团队协作开发。

2、Git的使用

在Windows系统下,使用Git主要通过从Git官方网站下载安装程序,按照提示安装,并确保选择安装Git Bash

而倘若使用PycharmIDEA等软件,这些集成开发环境(IDE)内置了对Git的支持,并包括了Git的命令行工具,因此可以直接在IDE中进行版本控制操作,而无需额外安装Git Bash。

3、Git常用命令

3.1 初始化仓库

将当前目录初始化为Git仓库:

git init  # 将当前目录初始化为Git仓库:

该命令执行完之后会在当前目录下生成一个.git 的目录文件。这个.git目录是Git版本控制系统的核心,包含了项目的所有版本历史、配置信息和元数据。这个目录的存在标志着该目录已经变成了一个Git仓库

3.2 克隆仓库

根据远程已有的Git仓库的URL地址,将项目从远程拷贝至本地

git clone <repo_url> <local_directory>

参数解释

repo_url:远程Git仓库的URL地址,.git后缀,例如 https://github.com/YuDongPan/Cannonical_Classifier.git
local_directory:拷贝到的本地目录,例如 ./my_project, 表示拷贝到my_project目录下。若不填,则默认拷贝至当前目录下

3.3 配置用户信息

配置Git用户信息是为了在提交历史中标识作者身份。通过设置用户姓名和邮箱,有助于协作、追踪版本历史、增加代码的可追溯性。

git config --global user.name "Your Name"
git config --global user.email "your.email@example.com"

配置后,在每次提交时,Git都会记录作者的姓名和邮箱。这使得你可以准确地知道谁对项目做出了贡献。配置是全局的,适用于所有Git仓库,有助于建立更有序和可信的版本控制环境。

3.4 提交代码(Commit)

当我们对本地仓库代码进行修改后,欲使得远程仓库代码进行同步更改,我们需要先将修改后的本地代码添加至暂存区(Staging Area)。

git add <filename> # 表示单独添加一个文件
git add . # 表示添加所有文件

若不确定当前目录下的文件添加状况, 可使用以下命令,查询各文件状态:

git status

之后实际提交(Commit)修改的代码至暂存区:

git commit -m "提交说明"

暂存区为每一次 Commit 的代码生成一个 Commit_Hash,使用以下命令,可以很方便追踪到项目的每一次修改记录。

git log

暂存区默认指向最后一次修改后提交的结果

3.5 推送代码(Push)

将本地仓库修改的代码Commit至了暂存区后,便可推送至远程Git仓库了。

git push origin <branch_name>

参数解释:

branch_name: 推送至的分支名称, 一般为master分支,但也可能为main分支或任何用户自定义的分支。

值得注意的是,若没有克隆现有仓库,欲将本地仓库链接到某个远程的Git仓库,则可通过以下命令进行链接:

git remote add origin <repo_url>

3.6 拉取代码(Pull)

git pull 命令用于从远程仓库获取最新的代码并将其合并到当前分支。它实际上是 git fetchgit merge 两个命令的组合。

git pull [<remote_repo>] [<remote_branch>:<local_branch>]

参数详解:

remote_repo:远程仓库。如果没有提供远程仓库,默认会使用远程仓库的 origin。
remote_branch, local_branch: 远程分支与本地分支。如果没有提供远程分支和本地分支,默认会拉取远程分支并与当前分支合并。

  • 获取远程更新 (git fetch)

    git pull 首先会调用 git fetch命令,从远程仓库下载最新的代码、分支等信息。但与 git fetch 不同,git pull 会将这些更新直接合并到当前分支,省去了额外的步骤。

  • 合并到本地分支(git merge)
    git pull 接着会调用 git merge 命令,将从远程仓库下载的最新代码合并到当前分支。

拉取并合并远程分支代码到当前本地分支

git pull origin main

这会从 origin 远程仓库的 main 分支拉取最新代码,并将其合并到当前所在的本地分支。

git pull

如果在 git pull 后不指定远程分支和本地分支,它将默认使用配置中的跟踪分支(通常是当前分支的远程对应分支)。

注意事项:
1、如果当前分支有未提交的更改,git pull 可能会导致冲突。在执行 pull 之前,建议先提交或者撤销本地的更改。
2、当拉取过程中有冲突时,需要手动解决冲突并执行 git pull 继续合并。

3.7 分支(Branch)

在Git中,分支(Branch)是指向某次提交的可移动指针。Git使用分支来管理不同的开发路径,允许在项目中同时进行多个独立的工作。Git中常用的分支类型有以下六种:

  1. 主分支(Master或Main): 通常是项目的默认分支,也是项目的主要开发线
  2. 特性分支(Feature Branch):用于开发新功能,通常从主分支创建。
  3. 开发分支(Development Branch):用于整合不同特性分支的中间分支。
  4. 发布分支(Release Branch):用于准备发布新版本的分支。
  5. 修复分支(Hotfix Branch): 用于紧急修复已发布版本中的bug。
  6. 远程分支(Remote Branch):指向远程仓库的分支,用于跟踪远程仓库的变化。

git branch 命令用于列出、创建、删除或重命名分支。

  • 切换到新分支
git branch

这将显示所有本地分支的列表,当前分支前会有一个 * 号标识。

  • 创建新分支
git branch <new_branch>

这会创建一个新分支,但不会自动切换到新分支。

  • 切换分支
git checkout <branch_name>

# 或者使用 -b 选项创建并切换到新分支:
git checkout -b <new_branch>

# 或者使用 `git switch` 命令进行分支切换:
git switch -c <new_branch>
  • 删除分支
git branch -d <branch_name>
 
# 这会删除指定的本地分支。如果分支还未合并,需要使用 -D 选项强制删除:
git branch -D <branch_name>
  • 查看远程分支
git branch -r

这会显示远程分支的列表。

  • 查看所有分支(包括远程):
 git branch -a

这会显示本地和远程分支的完整列表。

  • 重命名分支
 git branch -m <old_branch> <new_branch>

注意事项: 分支的创建、切换、删除和重命名等操作都是本地的,如果需要在远程仓库中应用这些变更,需要进行相应的推送和拉取操作。

3.8 远程仓库(Remote)

git remote 命令用于管理与远程仓库的关联。以下是一些常见的 git remote 相关的命令:

  • 查看远程仓库信息
git remote -v

这条命令将显示当前仓库关联的远程仓库信息,包括名称和URL。

  • 添加远程仓库
git remote add <remote_repo_name> <remote_repo_url>

参数解释:

remote_repo_name: 远程仓库名称
remote_repo_url: 远程仓库URL

这条命令将远程仓库添加到本地仓库的远程仓库列表中。

  • 移除远程仓库
git remote remove <remote_repo_name>

# or

git remote rm <remote_repo_name>

这两条命令可任选一条执行,执行后将从本地仓库的远程仓库列表中移除指定的远程仓库。

  • 查看远程仓库的详细信息
git remote show <remote_repo_name>

此命令用于显示指定远程仓库的详细信息,包括远程分支。

  • 重命名远程仓库
 git remote rename <old_remote_repo_name> <new_remote_repo_name>

此命令将本地仓库中已有的远程仓库重命名。

  • 修改远程仓库的URL
git remote set-url <remote_repo_name> <remote_repo_url>

此命令用于修改已有远程仓库的URL。

  • 拉取远程仓库的更新
git pull <remote_repo_name> <branch_name>

此命令从指定的远程仓库拉取更新并合并到本地分支。

  • 推送本地分支到远程仓库
 git push <remote_repo_name> <local_branch>:<remote_branch>

此命令用于将本地分支的提交推送到指定的远程分支。

3.9 撤销回退本地改动

  • 若我们需要将工作区中某个文件恢复到最近一次 commit 的状态,可使用以下命令:
git checkout -- <filename>

这个命令会用最近一次提交(commit)的版本覆盖工作区中的指定文件,取消对该文件的修改。如果在之前的提交中有对文件的修改,这个命令将会撤销这些修改。

  • 若我们需要将暂存区(Index)中的某个文件撤回到工作区,取消该文件的暂存状态, 可使用以下命令:
git reset HEAD <filename>

这个命令会取消之前使用 git add 将指定文件添加到暂存区的操作,将该文件从暂存区移回到工作区,但不改变工作区文件的实际内容。

  • 将当前分支的 HEAD 指针和工作区都回滚到上一次 commit 的状态。
 - git reset --hard HEAD^

这个命令是一个较为激进的操作,会将当前分支的 HEAD 指针和工作区都重置到上一次的提交(HEAD^ 表示上一个提交)状态。这样会丢弃所有未提交的本地修改,慎用,因为无法撤销。

3.10 更新本地仓库与远程仓库

1. git add . # 将本地代码添加到暂存区
2. git commit -m "second commit" # 提交本地代码到暂存区
3. git remote add origin url # 为远程仓库添加别名origin,并添加仓库url
4. git pull --rebase origin master # 将本地的未推送的提交叠加在从远程拉取的提交之上,避免创建不必要的合并提交                              
5. git push origin master # 将本地的master分支代码提交到远程仓库origin的master分支,将本地的提交同步到远程仓库

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

2024年美国大学生数学建模竞赛F题思路分析

题目 非法野生动物贸易对环境造成了负面影响&#xff0c;并威胁全球生物多样性。据估计&#xff0c;其涉及高达265亿美元的年交易额&#xff0c;被认为是全球所有非法交易中的第四大。[1] 你需要开发一个基于数据驱动的5年项目&#xff0c;旨在显著减少非法野生动物贸易。你的…

npm 和 yarn 的使用

安装 yarn npm i yarn -g查看版本 npm -v yarn --version切换 npm/yarn 的下包镜像源 // 查看当前的镜像源 npm config get registry// 切换淘宝镜像源 // 新的淘宝源&#xff0c;旧的淘宝源已于2022年05月31日零时起停止服务 npm config set registry https://registry.…

鸿蒙ArkUI日期选择组件

鸿蒙ArkUI日期选择组件&#xff0c;基于基础组件进行的二次封装的日期选择组件&#xff0c;快速实现日期选择。 /*** 日期*/ Component export default struct DiygwDate{//绑定的值Link Watch(onValue) value:string;// 隐藏值State valueField: string value;// 显示值Sta…

【靶场实战】Pikachu靶场不安全的文件下载漏洞关卡详解

Nx01 系统介绍 Pikachu是一个带有漏洞的Web应用系统&#xff0c;在这里包含了常见的web安全漏洞。 如果你是一个Web渗透测试学习人员且正发愁没有合适的靶场进行练习&#xff0c;那么Pikachu可能正合你意。 Nx02 不安全的文件下载漏洞概述 文件下载功能在很多web系统上都…

移动机器人激光SLAM导航(二):运动控制与传感器篇

参考引用 机器人工匠阿杰wpr_simulation 1. 机器人运动控制 1.1 测试环境安装 wpr_simulation 安装$ mkdir -p catkin_ws/src $ cd catkin_ws/src $ git clone https://github.com/6-robot/wpr_simulation.git $ cd wpr_simulation/scripts/ $ ./install_for_melodic.sh # 自…

Elasticsearch-内存结构

ElasticSearch的内存从大的结构可以分堆内存&#xff08;On Heap&#xff09;和堆外内存&#xff08;Off Heap&#xff09;。Off Heap部分由Lucene进行管理。On Heap部分存在可GC部分和不可GC部分&#xff0c;可GC部分通过GC回收垃圾对象&#xff0c;从而释放内存。不可GC部分不…

【项目日记(七)】第三层: 页缓存的具体实现(上)

&#x1f493;博主CSDN主页:杭电码农-NEO&#x1f493;   ⏩专栏分类:项目日记-高并发内存池⏪   &#x1f69a;代码仓库:NEO的学习日记&#x1f69a;   &#x1f339;关注我&#x1faf5;带你做项目   &#x1f51d;&#x1f51d; 开发环境: Visual Studio 2022 项目日…

three.js CSS3DRenderer、CSS3DObject渲染HTML标签

有空的老铁关注一下我的抖音&#xff1a; 效果&#xff1a; <template><div><el-container><el-main><div class"box-card-left"><div id"threejs" style"border: 1px solid red;position: relative;"><…

react 之 useInperativeHandle

useInperativeHandle是通过ref暴露子组件中的方法 1.场景说明-直接调用子组件内部的方法 import { forwardRef, useImperativeHandle, useRef } from "react"// 子组件const Son forwardRef((props, ref) > {// 实现聚焦逻辑const inputRef useRef(null)const …

【知识点】Java常用

文章目录 基础基础数据类型内部类Java IOIO多路复用重要概念 Channel **通道**重要概念 Buffer **数据缓存区**重要概念 Selector **选择器** 关键字final 元注解常用接口异常处理ErrorException JVM与虚拟机JVM内存模型本地方法栈虚拟机栈 Stack堆 Heap方法区 Method Area (JD…

npm安装报错,出现.staging

问题场景&#xff1a;同事发了一个本地的安装包&#xff0c;拿到了没仔细看&#xff0c;直接npm install&#xff0c;没有发现根目录下的package-lock.json。然后就发现安装一直不成功&#xff0c;还会卡主。并且在node_modules文件夹下还会出现.staging文件夹&#xff0c;正常…

计算机网络实验六

目录 实验6 静态路由与RIP协议配置 1、实验目的 2、实验设备 &#xff08;1&#xff09;内容一&#xff1a;&#xff08;静态路由配置&#xff09; &#xff08;2&#xff09;内容二&#xff1a;&#xff08;RIP协议配置&#xff09; 3、网络拓扑及IP地址分配 &#xff…

3593 蓝桥杯 查找最大元素 简单

3593 蓝桥杯 查找最大元素 简单 // C风格解法1&#xff0c;通过率100%&#xff0c;多组数据处理样式//str "abcdefgfedcba" //abcdefg(max)fedcba//str "xxxxx" //x(max)x(max)x(max)x(max)x(max)#include<bits/stdc.h>const int N 1e2 10;char …

无法在 word 中登录 Grammarly

目录 1. 情况描述 2. 解决方法 3. 原因分析 1. 情况描述 在浏览器中可以登录 Grammarly&#xff0c;但是在 word 中登录失败&#xff0c;大致如下图所示&#xff1a; 我自己没有截图&#xff0c;这是网上别人的图&#xff0c;但差不多都长这个样子。 2. 解决方法 我点击了…

量化交易学习4(投资组合基本认识)

1 如何衡量投资组合的收益率 1.1 投资组合收益率的计算方法 1.2 投资组合的绝对收益率和相对收益率 2 如何衡量投资组合的风险 2.1 风险的定义 风险是指在未来可能发生的不确定性事件所带来的潜在损失。 在投资领域中&#xff0c;风险通常指投资所面临的不确定性和潜在的损失…

react native错误记录

第一次运行到安卓失败 Could not find implementation class com.facebook.react.ReactRootProjectPlugin for plugin com.facebook.react.rootproject specified in jar:file:/D:/Android_Studio_Data/.gradle/caches/jars-9/o_3a1fd35320f05989063e7069031b710f/react-nativ…

钉钉群机器人-发送群消息

1、钉钉群创建机器人 添加完成后&#xff0c;要记住 Webhook 路径&#xff1b; 2、机器人接入文档网址 自定义机器人接入 - 钉钉开放平台 3、JAVA代码 import com.dingtalk.api.DefaultDingTalkClient; import com.dingtalk.api.DingTalkClient; import com.dingtalk.api.re…

JVM工作原理与实战(三十二):GC调优

专栏导航 JVM工作原理与实战 RabbitMQ入门指南 从零开始了解大数据 目录 专栏导航 前言 一、GC调优 二、GC调优的核心指标 总结 前言 JVM作为Java程序的运行环境&#xff0c;其负责解释和执行字节码&#xff0c;管理内存&#xff0c;确保安全&#xff0c;支持多线程和提供…

idea 中 tomcat 乱码问题修复

之前是修改 Tomcat 目录下 conf/logging.properties 的配置&#xff0c;将 UTF-8 修改为 GBK&#xff0c;现在发现不用这样修改了。只需要修改 IDEA 中 Tomcat 的配置就可以了。 修改IDEA中Tomcat的配置&#xff1a;添加-Dfile.encodingUTF-8 本文结束

网络协议与攻击模拟_13缓存DNS与DNS报文

一、缓存DNS服务器 1、引入缓存DNS 工作可能会遇到这样的场景&#xff0c;内网部署有一台缓存DNS服务器&#xff0c;这台服务器是由我们自己搭建的。为什么放在内网呢&#xff1f;因为我内网中的机器请求内网返回会比较快。第一次会慢点&#xff0c;因为有一个转发的过程&am…