Github学习

1.Git与Github

区别:

Git是一个分布式版本控制系统,简单的说就是一个软件,用于记录一个或若干个文件内容变化,以便将来查阅特点版本修订情况的软件。

Github是一个为用户提高Git服务的网站,简单说就是一个可以放代码的地方。Github除了提供Git的Web界面外,还提供了订阅,关注,讨论组,在线编辑器等丰富的功能。

2.Git安装

官网安装

3.Git的使用

Git本地操作的三个区域:

Git Repository(Git 仓库):最终确定的文件保存到仓库,成为一个新的版本,并且对他人可见

暂存区:暂存已经修改的文件最后统一提交到git仓库中

工作区(Working Directory):添加,编辑,修改文件等动作

本地仓库操作

1.在安装好后首先使用需要进行全局配置

桌面空白处右键,点击 Git Bash Here 打开Git命令行窗口

git config --global user.name "用户名"

get config --global user.email "邮箱地址"

设置用户名和邮箱,把参数去掉之后可以查看设置是否成功

2.创建仓库

当我们需要人Git去管理某个新项目或已存在项目的时候,就需要创建仓库了。创建仓库时使用的目录不一定要求是空目录,非空目录也可以,所有目录不能存在中文。

创建文件夹

进入文件夹

Git仓库初始化

git init

执行后会在项目目录下创建 .git的隐藏目录,不能删除,也不能随意修改其中的内容。

3.Git常用指令操作

查看当前状态: git status

添加到缓冲区: git add 文件名

注:git add 指令,可以添加一个文件,也可以同时添加多个文件

        git add 文件名

        git add 文件名1 文件名2 文件名3 ...

        git add .   添加当前目录到缓冲区

提交至版本库: git commit -m "注释内容,提交说明"

4.版本回退

1.查看版本,确定需要回去的时刻点

git log

git log --pretty=oneline     放在一行显示

2.回退

git reset --hard 提交编号(id)

回退之后,要想再回到之前最新的版本时,需要使用指令去查看历史操作,以得到最新的commit id

git reflog

远程仓库

1.线上创建

github点击create repositroy即可

2.基于http协议使用

1.创建一个空目录,名称随便,进入目录

2.使用clone指令克隆线上仓库到本地

git clone 线上仓库地址

3.在仓库上做对应的操作

提交暂存区

提交本地仓库

提交线上仓库

git push

首次往线上仓库提交时候会失败,报错或弹窗,是因为鉴权没过,需要修改 ".git/config"文件内容

添加gitHub的用户名和密码,如果是弹窗,则选择浏览器方式授权即可

拉取线上仓库 

git pull

3.基于ssh协议

相比于https方式,只是影响github对于用户的身份鉴权方式,对于git的具体操作不影响

1.生成客户端公私钥文件(需安装OpenSSH)

ssh-keygen -t rsa -C "邮箱"
# 影响为登录github的邮箱即可

2.将公钥上传到Github 

 把生成的密钥文件打开,将其中的内容复制上传至github

分支管理

1.相关指令

查看分支: git branch

创建分支: git branch 分支名

         git push --set-upstream origin [master]   创建完成之后执行该命令,于远程仓库建立连接,master为自定义分支名称

切换分支: git checkout 分支名

切换并创建分支: git checkout -b 分支名

删除分支: git branch -d 分支名

        删除分支时,要先退出要删除的分支,然后再删除

合并分支: git merge 被合并的分支名

2.冲突的产生与解决

发送冲突时先git pull代码,此时git已经将线上与本地仓库的冲突合并到对应的文件中,需要手动打开对应文件,保留需要的,删除不需要的。最后重新提交。

忽略文件

        提交代码时有些文件长时间不需要提交,可以将该文件设置为忽略文件。忽略文件需要新建一个 .gitignore的文件,该文件用于声明忽略文件或不忽略文件的规则,规则对当前目录及其子目录生效。

        该文件因为没有文件名,没办法直接在windows目录下直接创建,可以通过命令行Git Bash来touch创建。

在.gitignore文件中编写规则,#开头为注释

/文件夹名称/      过滤整个文件夹

*.zip       过滤所有.zip文件

/文件夹名称/文件名    过滤某个具体文件

!index.php     不过滤具体某个文件

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

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

相关文章

数字化社会的引擎:揭示Facebook的影响力

在当今数字化社会中,社交媒体平台扮演着至关重要的角色,而Facebook作为其中的巨头之一,其影响力不可忽视。本文将深入探讨Facebook的影响力,从多个角度揭示其在数字化社会中的引擎作用。 1. 社交互动的核心平台 Facebook作为社交…

使用Python递归重命名文件和文件夹

使用 Python 递归重命名文件和文件夹可以通过 os 模块和 os.path 模块来完成。下面是一个示例代码,演示如何递归地重命名文件和文件夹: 1、问题背景 在研究大型数字档案时,需要将这些档案复制到本地存储进行保存。这些档案通常存储在 USB 驱…

【机器学习】LoFTR:革命性图像特征批评技术等领跑者

LoFTR:革命性图像特征匹配技术的领跑者 一、引言二、LoFTR技术的创新之处三、LoFTR技术的实现原理四、LoFTR技术的代码实例五、结语 一、引言 在3D计算机视觉领域,图像特征匹配技术一直是研究的热点和难点。随着技术的不断发展,传统的特征检…

力扣:48. 旋转图像(Java)

目录 题目描述:输入:输出:代码实现: 题目描述: 给定一个 n n 的二维矩阵 matrix 表示一个图像。请你将图像顺时针旋转 90 度。 你必须在 原地 旋转图像,这意味着你需要直接修改输入的二维矩阵。请不要 使…

图神经网络实战(10)——归纳学习

图神经网络实战(10)——归纳学习 0. 前言1. 转导学习与归纳学习2. 蛋白质相互作用数据集3. 构建 GraphSAGE 模型实现归纳学习小结系列链接 0. 前言 归纳学习 (Inductive learning) 通过基于已观测训练数据,建立一个通用模型,使模…

Maven:Maven基础

Maven apache旗下的一个开源项目,一款用于管理和构建java项目的工具 什么是Maven 一个项目管理和构建工具,基于项目对象模型(POM)的概念,通过一小段描述信息来管理项目的构建,报告和文档. Maven的作用 依赖管理 方便快捷的管理项目依赖的资源jar包,避免版本冲突问题 统一…

C++的数据结构(四):队列

在数据结构中,队列(Queue)是一种特殊的线性表,只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作。队列中没有元素时,称为空队列。队列的…

小程序的小组件

进度的组件 文字换行过滤 以及 排序 简单易懂 只为了记录工作 <template><div><ProgressBar :progress"progress" /><button click"increaseProgress">增加进度</button><view class"goods-name">12…

电脑锁屏快捷键是哪个?1分钟弄懂锁屏设置!

“当我暂时不需要使用电脑时&#xff0c;想给电脑设置锁屏&#xff0c;有朋友知道电脑锁屏快捷键是哪个吗&#xff1f;” 随着信息技术的飞速发展&#xff0c;我们在日常生活中经常需要使用电脑。然而&#xff0c;当我们暂时离开电脑时&#xff0c;如何确保电脑信息安全&#x…

【解决】Android APK文件安装时 已包含数字签名相同APP问题

引言 在开发Android程序过程中&#xff0c;编译好的APK文件&#xff0c;安装至Android手机时&#xff0c;有时会报 包含数字签名相同的APP 然后无法安装的问题&#xff0c;这可能是之前安装过同签名的APP&#xff0c;但是如果不知道哪个是&#xff0c;无法有效卸载&#xff0c;…

图文详解:synchronized关键字 及其底层原理

目录 一.线程安全问题 二.synchronized关键字 ▐ synchronized图解 ▐ 可重入锁及图解 ▐ synchronized用于方法上 三.Java标准库中synchronized的使用 四.synchronized的底层实现原理 一.线程安全问题 线程安全是指在多线程环境下&#xff0c;对共享资源的访问不会导致…

详解循环队列——链表与数组双版本

前言&#xff1a;本节内容主要是讲解循环队列。 在本篇中会讲到两个版本——数组版本、链表版本。本篇内容适合正在学习数据结构队列章节或者已经学过队列但对循环队列感觉模糊的友友们 。 首先先来看一下什么是循环队列 什么是循环队列 因为是刚开始讲解&#xff0c; 所以我们…

【基础绘图】 10.饼图

效果图&#xff1a; 主要步骤&#xff1a; 1. 数据准备&#xff1a;自己赋值的随机数 2. 图像绘制&#xff1a;绘制饼图 详细代码&#xff1a;着急的直接拖到最后有完整代码 步骤一&#xff1a;导入库包及图片存储路径并设置中文字体为宋体&#xff0c;西文为新罗马&#…

totoriseSVN 常见问题

1. SVN 无法 clean up 上传时没有关闭 Excel&#xff0c;导致传入了一些临时文件&#xff08;文件名以$开头&#xff09;&#xff0c;关闭文件后临时文件自动删除&#xff0c;导致 SVN 版本错乱&#xff0c;使用 CleanUp 功能无效 更新时提示【Previous operation has not fin…

win7 phpstudy 多站点无法保存hosts的原因

1、先找到hosts文件位置 C:\Windows\System32\drivers\etc hosts文件不是txt的后缀&#xff0c;它是一个系统文件 2、如果不显示需要查找隐藏文件 组织-》文件夹和搜索选项-》查看-》取消隐藏文件夹的的√ 3、文件无法编辑 属性不要勾选只读

【SAP-FICO】SAP-FICO生产订单-结算规则配置路径(OKO7)

需求&#xff1a; 作为一个ABAPer&#xff0c;有接到一个狗屁倒灶的配置需求&#xff0c;要求如下&#xff0c;给生产订单的结算规则显示出来 图1&#xff1a;找一个生产订单&#xff0c;显示其结算规则 CO03→菜单栏-表头→结算规则 图2&#xff1a;查看该生产订单&#xff0c…

SMB/RPC协议分析之-命名/匿名管道pipe

在前面的文章中&#xff0c;介绍了SMB协议共享相关的内容&#xff0c;详见我的专栏《网络攻防协议实战分析》&#xff0c;连接这里。在SMB协议中往往需要连接到对应的远程管道&#xff0c;如果你经常接触到SMB协议&#xff0c;相信你对于lsass&#xff0c;svcctl等多种命名管道…

数据结构-二叉树-AVL树(平衡二叉树)

红黑树是平衡二叉树的一个变种。 一、 产生平衡二叉树的原因。 二叉搜索树的问题在于极端场景下退化为类似链表的结构&#xff0c;所以搜索的时间复杂度就变成了O(N)。为了保证二叉树不退化为链表&#xff0c;我们必须保证二叉树的的平衡性。 二叉平衡搜索树就是解决上面的问…

职场新人小王的沟通挑战与成长

近日&#xff0c;职场新人小王遇到了一个沟通上的小难题。作为刚刚踏入社会的新鲜人&#xff0c;小王在工作会议上因为一次直接的反馈而无意间触动了同事的敏感神经&#xff0c;导致双方关系稍显紧张。 在一次团队会议上&#xff0c;小王被要求分享对项目进度的看法以及建议。他…

【图解计算机网络】TCP 重传、滑动窗口、流量控制、拥塞控制

TCP 重传、滑动窗口、流量控制、拥塞控制 TCP 重传超时重传快速重传 滑动窗口流量控制拥塞控制慢启动拥塞避免拥塞发生快速恢复 TCP 重传 TCP重传是当发送的报文发生丢失的时候&#xff0c;重新发送丢失报文的一种机制&#xff0c;它是保证TCP协议可靠性的一种机制。 TCP重传…