【持续更新】Github实用命令
Intro
最近高强度使用github,遂小计于此作为备忘。
Basic
github是一个代码管理软件,能够track文件变动并且管理版本,是当代coding必不可少的工具。当你安装好github在本地以后,你可以通过以下命令初始化当前文件夹(假设是/WorkingSpace)的github管理
cd WorkingSpace
git init
此时/WorkingSpace下会创建一个隐藏文件夹.git,它负责储存所有有关github的内容。
在初始化之后,当前的仓库并没有track任何文件。运行以下命令将file加入track列表中
git add file
正如linux的文件操作,你可以使用.来代表当前文件夹下的所有文件,通过以下操作你可以一键加入当前文件夹下的所有文件
git add .
但是在复杂仓库的管理时切忌直接使用以上命令,很容易track很多无意义的文件,导致不必要的冗余与开销。你可以创建.gitignore文件在/WorkingSpace下,直接将忽略的文件写在.gitignore中,每个文件一行,如
file
每一次git add操作会将文件放入缓存区,使用git commit将当前缓存区的内容记录为一个新的版本
git commit -m "This is your commit message."
每一次commit都有对应的ID,你可以通过reset命令回到某个历史的版本中
git reset XXXXXXXXXXXXXXXXX
此类reset为soft reset,只会改变当前的版本号,并不会改变本地的文件。
推荐使用VS Code的github功能,你可以直观地使用进行管理、查看版本号。VS Code在此命令后会显示旧版本与本地文件的区别。
你还可以使用hard reset改变本地的代码(本地代码将强制更改为某个版本的代码,很难找回!!!)。
git reset --hard XXXXXXXXXXXXXXXXX
你还可以使用HEAD表示当前最新的版本号,这个命令可以帮助你快速清空缓存区。
git reset --hard HEAD
事已至此你成功维护了本地的github仓库。
照着github的Create Repository,你可以创建一个线上的github仓库,便于备份与合作。你也可以直接clone一个远程仓库到本地
git clone git@github.com:UserName/RepoName.git
git clone https://github.com/UserName/RepoName.git
你可以用pull将线上拉取到本地,用push将本地更新到线上
git pull
git push
由于git的要求,你必须从当前git的最新版本进行更新,再push,否则你需要先与最新的版本进行手动的commit。由于这个特性更多时候版本更新是线性的,在最后再merge起来。
Merge:你可以使用git pull拉取远程仓库,此时相同的文件将会存在本地和远程两个版本,你需要逐行确认保留远程版本还是本地版本(在VS Code上)。
你也可以使用hard命令强制覆盖Remote仓库(非常危险,很难找回!!!)
git push --hard
Branch
获取当前Local与Remote的Branch list.
git branch -a
从remote上新建分支(LocalBranch的名字尽量与RemoteBranch名字相同,否则有可能会出现问题)
git checkout -b LocalBranch origin/RemoteBranch
切换至LocalBranch(需先将缓存区清空,如git reset --hard HEAD)
git checkout LocalBranch
同一份代码也可以有不同的remote repo,你可以将本地仓库与某个远程仓库绑定,你可以用这个方法clone别人的代码并维护一个属于自己的仓库
git remote set-url origin git@github.com:UserName/RepoName.git
当remote的branch信息更新时,本地需要额外的fetch进行更新(prune会删除remote中不存在的branch)
git fetch --prune
你可以使用-d删除本地分支(-D为不顾及是否merge强制删除)
git branch -d LocalBranch
Bug
fatal: The current branch main has multiple upstream branches, refusing to push.
- 原因是当前branch在push的时候不知道自己的上游是什么,没有关联起来。使用
--set-upstream将本地LocalBranch与远程的RemoteBranch关联起来。
git push --set-upstream LocalBranch RemoteBranch
当使用git branch -a时,会输出
* mainremotes/origin/main
这意味着--set-upstream的姿势应该是
git push --set-upstream origin main
相关文章:
【持续更新】Github实用命令
Intro 最近高强度使用github,遂小计于此作为备忘。 Basic github是一个代码管理软件,能够track文件变动并且管理版本,是当代coding必不可少的工具。当你安装好github在本地以后,你可以通过以下命令初始化当前文件夹(…...
docker 容器的基本使用
docker 容器 一、docker是什么? 软件的打包技术,就是将算乱的多个文件打包为一个整体,打包技术在没有docker容器之前,一直是有这种需求的,比如上节课我把我安装的虚拟机给你们打包了,前面的这种打包方式是…...
css让按钮放在最右侧
要将 el-button 按钮放在最右侧,可以使用多种方法,具体取决于使用的布局方式和样式库。以下是几种常见的解决方案: 方法 1:使用 CSS Flexbox Flexbox 是一种非常灵活的布局方式,可以轻松实现水平或垂直对齐。你可以将…...
8K+Red+Raw+ProRes422分享5个影视级视频素材网站
Hello,大家好,我是后期圈! 在视频创作中,电影级的视频素材能够为作品增添专业质感,让画面更具冲击力。无论是广告、电影短片,还是品牌宣传,高质量的视频素材都是不可或缺的资源。然而ÿ…...
Linux网络——UDP的运用
Linux网络——UDP的运用 文章目录 Linux网络——UDP的运用一、引入二、服务端实现2.1 创建socket套接字2.2 指定网络接口并bind2.3 接收数据并处理2.4 整体代码2.5 IP的绑定的细节 三、用户端实现3.1 创建套接字3.2 指定网络接口3.3 发生数据并接收3.4 绑定问题 四、代码五、UD…...
项目亮点案例
其实对我来说是日常操作,但是如果在面试的时候面试者能把日常的事情总结好发出来,其实足矣。 想让别人认同项目,选取的示例需要包含以下要素: 亮点项目四要素:明确的目标,问题点,解决方法和结果…...
Retrofit源码分析:动态代理获取Api接口实例,解析注解生成request,线程切换
目录 一,Retrofit的基本使用 1.定义api接口 2.创建Retrofit实例 3.获取api接口实例发起请求 二,静态代理和动态代理 1,静态代理 2,动态代理 三,动态代理获取Api接口实例 四,解析接口方法注解&…...
范德蒙矩阵(Vandermonde 矩阵)简介:意义、用途及编程应用
参考: Introduction to Applied Linear Algebra – Vectors, Matrices, and Least Squares Stephen Boyd and Lieven Vandenberghe 书的网站: https://web.stanford.edu/~boyd/vmls/ Vandermonde 矩阵简介:意义、用途及编程应用 在数学和计算科学中&a…...
【中标麒麟服务器操作系统实例分享】java应用DNS解析异常分析及处理
了解更多银河麒麟操作系统全新产品,请点击访问 麒麟软件产品专区:https://product.kylinos.cn 开发者专区:https://developer.kylinos.cn 文档中心:https://document.kylinos.cn 情况描述 中标麒麟服务器操作系统V7运行在 ARM…...
网安瞭望台第17期:Rockstar 2FA 故障催生 FlowerStorm 钓鱼即服务扩张现象剖析
国内外要闻 Rockstar 2FA 故障催生 FlowerStorm 钓鱼即服务扩张现象剖析 在网络安全的复杂战场中,近期出现了一个值得关注的动态:名为 Rockstar 2FA 的钓鱼即服务(PhaaS)工具包遭遇变故,意外推动了另一个新生服务 Flo…...
玩转OCR | 探索腾讯云智能结构化识别新境界
📝个人主页🌹:Eternity._ 🌹🌹期待您的关注 🌹🌹 ❀ 玩转OCR 腾讯云智能结构化识别产品介绍服务应用产品特征行业案例总结 腾讯云智能结构化识别 腾讯云智能结构化OCR产品分为基础版与高级版&am…...
idea2024创建JavaWeb项目以及配置Tomcat详解
今天呢,博主的学习进度也是步入了JavaWeb,目前正在逐步杨帆旗航,迎接全新的狂潮海浪。 那么接下来就给大家出一期有关JavaWeb的配置教学,希望能对大家有所帮助,也特别欢迎大家指点不足之处,小生很乐意接受正…...
外连接转AntiJoin的应用场景与限制条件 | OceanBase SQL 查询改写系列
在《SQL 改写系列:外连接转内连接的常见场景与错误》一文中,我们了解到谓词条件可以过滤掉连接结果中的 null 情形的,将外连接转化为内连接的做法是可行的,正如图1中路径(a)所示。此时,敏锐的你或许会进一步思考&#…...
华为实训课笔记 2024 1223-1224
华为实训 12/2312/24 12/23 [Huawei]stp enable --开启STP display stp brief --查询STP MSTID Port Role STP State Protection 实例ID 端口 端口角色 端口状态 是否开启保护[Huawei]display stp vlan xxxx --查询制定vlan的生成树计算结…...
MySQL超详细安装配置教程(亲测有效)
目录 1.下载mysql 2.环境配置 3.安装mysql 4.navicat工具下载与连接 5总结 1.下载mysql mysql下载--MySQL :: 下载 MySQL 社区服务器 下载的时候这里直接逃过就行 我这里的版本是最新的mysql8.0.37 下载完成之后,将压缩包进行解压 这里我建议大…...
MySQL 8.0:explain analyze 分析 SQL 执行过程
介绍 MySQL 8.0.16 引入一个实验特性:explain formattree ,树状的输出执行过程,以及预估成本和预估返 回行数。在 MySQL 8.0.18 又引入了 EXPLAIN ANALYZE,在 formattree 基础上,使用时,会执行 SQL &#…...
信管通低代码信息管理系统应用平台
目前,国家统一要求事业单位的电脑都要进行国产化替代,替代后使用的操作系统都是基于linux的,所有以前在WINDOWS下运行的系统都不能使用了,再者,各单位的软件都很零散,没有统一起来。需要把日常办公相关的软…...
git推送本地仓库到远程(Gitee)
目录 一、注册创建库 二、创建仓库 三、推送本地仓库到远程 1.修改本地仓库用户名和邮箱 2.本地库关联远程仓库 3.拉取远程仓库的文件 4.推送本地库的文件 5.查看远程仓库 四、远程分支查看 1.查看远程分支 2.修改test.txt文件 一、注册创建库 Gitee官网࿱…...
【C++语言】多态
一、多态的概念 多态的概念:通俗来说,就是多种形态,具体点就是去完成某种行为,当不同的对象去完成时会产生出不同的状态。 我们可以举一个例子: 比如买票这种行为,当普通人买票时,是全价买票&am…...
ThinkPHP 吸收了Java Spring框架一些特性
ThinkPHP 吸收了Java Spring框架一些特性,下面介绍如下: 1、controller 控制器层 存放控制器层的文件,用于处理请求和响应 2、model 实体类 存放实体类的文件,用于定义数据模型 3、dao DAO层 存放DAO(数据访问…...
GHelper终极指南:5步解锁华硕笔记本隐藏性能,告别Armoury Crate臃肿
GHelper终极指南:5步解锁华硕笔记本隐藏性能,告别Armoury Crate臃肿 【免费下载链接】g-helper Lightweight, open-source control tool for ASUS laptops and ROG Ally. Manage performance modes, fans, GPU, battery, and RGB lighting across Zephyr…...
告别驱动烦恼:Windows平台终极ADB安装工具全解析
告别驱动烦恼:Windows平台终极ADB安装工具全解析 【免费下载链接】Latest-adb-fastboot-installer-for-windows A Simple Android Driver installer tool for windows (Always installs the latest version) 项目地址: https://gitcode.com/gh_mirrors/la/Latest-…...
Stable-Diffusion-v1-5-archiveWebUI插件开发指南:Python扩展接口与SDK文档
Stable-Diffusion-v1-5-archive WebUI插件开发指南:Python扩展接口与SDK文档 1. 引言:为什么需要开发自己的WebUI插件? 如果你已经用了一段时间的Stable Diffusion v1.5 Archive,可能会发现一个痛点:每次生成图片都要…...
DCT-Net人像卡通化:SpringBoot后端集成指南
DCT-Net人像卡通化:SpringBoot后端集成指南 1. 引言 你有没有想过给自己的社交头像换个卡通风格?或者为应用用户提供一键生成卡通头像的功能?DCT-Net人像卡通化技术让这变得简单。这个模型能够将普通人像照片转换成各种风格的卡通形象&…...
fSpy终极指南:5分钟学会免费开源3D相机匹配神器
fSpy终极指南:5分钟学会免费开源3D相机匹配神器 【免费下载链接】fSpy A cross platform app for quick and easy still image camera matching 项目地址: https://gitcode.com/gh_mirrors/fs/fSpy 在3D建模、建筑可视化和影视特效领域,如何将2D照…...
Springboot 实现多数据源(PostgreSQL 和 SQL Server)连接于
一、环境准备 Free Spire.Doc for Python 是免费 Python 文档处理库,无需依赖 Microsoft Word,支持 Word 文档的创建、编辑、转换等操作,其中内置的 Markdown 解析能力,能高效实现 Markdown 到 Doc/Docx 格式的转换,且…...
从Visio到PPT:科研绘图工具选择的效率革命与实战避坑
1. 科研绘图工具变迁:为什么越来越多人放弃Visio? 十年前我刚读博士时,实验室师兄教我的第一件事就是用Visio画流程图。那时候觉得这个软件真神奇,拖拽几个方框就能做出漂亮的示意图。但最近三年,我发现身边90%的科研同…...
张雪峰被蒸馏永生引争议!有人支持,但很多人不看好
①张雪峰刚离世不久,GitHub 上就出现了多个「张雪峰.skill」。先有位开发者收集了张雪峰生前的 5 本著作、十余条深度采访、30 余条语录及多个关键决策记录,提炼出其独特的咨询风格、决策逻辑与表达方式,将其打包为一款 AI 智能体技能文件。后…...
Meta-Llama-3-8B-Instruct开箱即用:小白也能5分钟搭建AI对话应用
Meta-Llama-3-8B-Instruct开箱即用:小白也能5分钟搭建AI对话应用 1. 引言:为什么选择Meta-Llama-3-8B-Instruct? 如果你正在寻找一个既强大又容易上手的AI对话模型,Meta-Llama-3-8B-Instruct绝对值得考虑。这个80亿参数的模型在…...
DAMO-YOLO功能体验:实时动态交互界面,滑块调节检测灵敏度
DAMO-YOLO功能体验:实时动态交互界面,滑块调节检测灵敏度 想象一下,你正在处理一批监控录像,需要快速找出所有出现车辆的片段。传统方法可能需要你逐帧查看,或者依赖一个“死板”的检测系统,要么漏掉一些模…...
