百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

GitHub|清晰理解本地目录、暂存区、本地仓库、远程仓库的交互

wptr33 2025-07-07 23:38 3 浏览

GitHub 是一个在线平台,旨在促进在一个共同项目上工作的个人之间的代码托管、版本控制和协作。通过该平台,无论何时何地,都可以对项目进行操作(托管和审查代码,管理项目和与世界各地的其他开发者共同开发软件)。GitHub 平台为开源项目和私人项目都提供了项目处理功能。

GitHub is a code hosting platform for version control and collaboration. It lets you and others work together on projects from anywhere.

Github是一个版本控制和项目合作的代码托管平台。它让你和其他任何地方的伙伴共同进行一个项目。

Git是分布式管理的版本控制器,它的特点是版本控制可以不依赖网络,对分支和合并有更好的支持。

Git每一个终端都是一个仓库,客户端并不只提取最新版本的文件快照,而是把原始的代码仓库完整地镜像下来。每一次的提取操作,实际上都是一次对代码仓库的完整备份。

Git工具(git bash)是一个命令行工具,可用于操作本地Gig仓库及与远程GitHub仓库的交互。

git对文件的操作都是在四大域上进行的(工作目录,暂存区,仓库,远程仓库),文件可以在四大域内与四大域间进行各种操作。(有一个例外,进行“git stash”系列操作时,文件可能被保存到四大域外的堆栈中)

1 新建远程仓库和本地仓库

1.1 github上新建远程仓库
https://github.com/reachone01/ency

1.2 本地项目文件夹右击,Git Bash Here(或者用cd命令切换到此文件夹路径);

1.3 $ git init (会在此路径新建一个隐藏属性.git文件夹,此路径以master为别名)

执行git init后,bash提示符改变为:

wwuhnwu01@wwuhnwu01 MINGW32 /d/wwuhn.github.io (master)

bash提示符字符串暂时不会包括(master),要操作到后一步才会有,如果有,表示此路径下有了.git文件夹(本地仓库,或叫索引库,隐藏属性),最好删除此文件夹后再操作。

1.4 $ git add . (工作目录→暂存区(Index))

1.5 $ git commit -m "initial" (暂存区(Index)→本地仓库(History))

1.6 $ git remote add dst
https://github.com/reachone01/ency.git (与远程仓库建立一个叫dst的连接)

1.7 $ git push -u dst master (本地仓库(History)→远程仓库)

如果参数是-f,则是强制上传,远程仓库的内容会被强制覆盖。

2 在远程仓库中新增文件夹

2.1 本地文件夹push

2.1 远程仓库新建一分支dev

要理解分支,分支并不是全新的或空白的,而是对master的clone,合并(pull request)时会检查是否在master的基础上有更新,才会考虑合并。

如果是自己的个人网站,推荐的做法是新建仓库,旧的仓库做为备份,然后更改名称,删除不需要的仓库即可。

2.1.2 本地文件夹右击,Git Bash Here(或者用cd命令切换到此文件夹路径);

2.1.3 $ git init (会在此路径新建一个隐藏属性.git文件夹,此路径以master为别名)

2.1.4 $ git remote add dst
https://github.com/reachone01/ency.git (与远程仓库建立一个叫dst的连接)

2.1.5 $ git pull dst master (远程仓库中的文件clone到本地目录)

需要注意的是,远程仓库中相同的文件或文件名会覆盖掉本地目录中的文件或文件名。

2.1.6 $ git add . (工作目录→暂存区(Index))

2.1.7 $ git commit -m "initial" (暂存区(Index)→本地仓库(History))

2.1.8 $ git push -u dst master:dev (本地仓库(History)→远程仓库)

2.1.9 远程仓库pull request

如果两个分支是分支不同的递交记录(entirely different commit histories),是不能合并的(例如完全不同的push -f )。

2.1.10 删除dev分支

2.2 直接在远程仓库上新建文件夹并上传(可拖曳)

2.2.1 在远程仓库新建文件→dir/newfile.txt,即可新建一个dir文件夹;

2.2.2 此时可以点击上传按钮,只能框选文件(不能选择文件夹),也可直接拖曳文件或文件夹,但不能超过100个。

-End-

相关推荐

抢先体验Windows 10 20H2新功能,该怎样操作呢?

Win10系统通常会在一年当中进行两次重大更新,分别于上下半年分别推出。上半年的更新主要针对功能的变化,而下半年则是提升系统稳定性。最近Win10下半年最重要的更新Windows1020H2已经开...

教程:如何关闭Win10/Win8.1/Win7管理共享

教程:如何关闭Win10/Win8.1/Win7管理共享出处:IT之家原创(晨风)默认情况下,Windows会创建一些隐藏的共享文件夹,这些文件夹在名称的末尾都有美元“$”标志。当用户在文件资源管理...

Win11学院:如何强制让Windows 11设备蓝屏

IT之家12月15日消息,在Win11系统中蓝屏(BSoD)也称为“停止错误”(StopError)和“错误检查”(BugCheck),通常情况下只有在遇到关键问题的时候才会出现。显然...

微软承认Windows 10新BUG:错误显示没有网络连接

来源:cnBeta.COM在7月补丁星期二活动中,微软发布的累积更新已经修复Windows10系统中的大量BUG。不过近日,微软承认了存在于Windows10May2020(20H...

一课译词:双标(双标英文怎么写)

PhotobyMarkusSpiskeonUnsplash“双标[shuāngbiāo]”,网络流行语,完整说法是“双重标准”,翻译为“doublestandard”。“双标”是指“对同...

知识科普:USB端口如何禁用和解锁?

2015-07-3005:32:00作者:赵为民经常有人会说,我要保护我的笔记本电脑的USB端口,在未经授权的情况下不能够访问。是否有专业的软件可以将USB端口锁死,然后在需要的时候解锁呢?是的,...

小迈科技 X Hologres:高可用的百亿级广告实时数仓建设

通过本文,我们将会介绍小迈科技如何通过Hologres搭建高可用的实时数仓。一、业务介绍...

Modbus-RTU通信(modbus rtu rtu over tcp)

通常情况下我们做Modbus通信的时候,都会先用测试软件进行测试,等通信测试通过之后,我们才会进行移植,我这边主要讲的是移植到PLC上,我现在这边还没有开始做PLC程序,那先把前期的用测试软件如何测...

警惕!利用Github进行水坑攻击安全风险通告

2022年5月19日,亚信安全CERT监测发现Github账户为rkxxz的用户发布了CVE-2022-26809和CVE-2022-24500的项目,项目内容介绍为:CVE-2022-26809...

手机越用越慢?小编教你如何用黑狱冰箱调教它!

看完智趣狗昨天推送的《看完秒懂!这就是Android手机越用越卡的原因!》一文后,我们不难知晓手机越用越慢多是体量更大的APP,以及APP之间相互唤醒而导致资源过度消耗引起的。所以,想让手机恢复高效率...

秒杀系统—3.第二版升级优化的技术文档一

大纲1.秒杀系统的服务细分和服务定位...

Redis命令介绍(二十五)HSET & HSETNX

HSET将上送的键值对保存在key中存储的哈希表中。如果key不存在则创建一个新的哈希表。如果key已存在,则覆盖。在4.0版本后,HSET支持同时上送多键值对。...

IDEA用上这十大插件就很舒服(intellij idea插件推荐)

本文翻译自国外论坛medium,原文地址:https://medium.com/@xjpp22/top-10-plugins-for-intellij-idea-you-dont-want-to-m...

常用 Git 命令清单(git常用命令速查表)
常用 Git 命令清单(git常用命令速查表)

下面是整理的常用Git命令清单。几个专用名词的译名如下。...

2025-07-07 23:38 wptr33

GitHub|清晰理解本地目录、暂存区、本地仓库、远程仓库的交互

GitHub是一个在线平台,旨在促进在一个共同项目上工作的个人之间的代码托管、版本控制和协作。通过该平台,无论何时何地,都可以对项目进行操作(托管和审查代码,管理项目和与世界各地的其他开发者共同开发...