Git 是分散式的版本控制系统, 从架设、简易操作、设定, 此篇主要是整理基本操作、远端操作等.
注: Git 的范围太广了, 把这篇当作是初学入门就好了.
注意事项
由project/.git/config 可知: (若有更多, 亦可由此得知)
origin(remote) 是Repository 的版本
master(branch) 是local 端, 正在修改的版本
平常没事不要去动到origin, 如果动到, 可用git reset --hard 回覆到没修改的状态.
Git 新增档案
git add . # 将资料先暂存到staging area, add 之后再新增的资料, 于此次commit 不会含在里面.
git add filename
git add modify-file # 修改过的档案, 也要add. (不然commit 要加上-a 的参数)
git add -u # 只加修改过的档案, 新增的档案不加入.
git add -i # 进入互动模式
Git 删除档案
git rm filename
Git 修改档名、搬移目录
git mv filename new-filename
Git status 看目前的状态
git status # 看目前档案的状态
Git Commit
git commit
git commit -m 'commit message'
git commit -a -m 'commit -message' # 将所有修改过得档案都commit, 但是新增的档案还是得要先add.
git commit -a -v # -v 可以看到档案哪些内容有被更改, -a 把所有修改的档案都commit
Git 产生新的branch
git branch # 列出目前有多少branch
git branch new-branch # 产生新的branch (名称: new-branch), 若没有特别指定, 会由目前所在的branch / master 直接复制一份.
git branch new-branch master # 由master 产生新的branch(new-branch)
git branch new-branch v1 # 由tag(v1) 产生新的branch(new-branch)
git branch -d new-branch # 删除new-branch
git branch -D new-branch # 强制删除new-branch
git checkout -b new-branch test # 产生新的branch, 并同时切换过去new-branch
# 与remote repository 有关
git branch -r # 列出所有Repository branch
git branch -a # 列出所有branch
Git checkout 切换branch
git checkout branch-name # 切换到branch-name
git checkout master # 切换到master
git checkout -b new-branch master # 从master 建立新的new-branch, 并同时切换过去new-branch
git checkout -b newbranch # 由现在的环境为基础, 建立新的branch
git checkout -b newbranch origin # 于origin 的基础, 建立新的branch
git checkout filename # 还原档案到Repository 状态
git checkout HEAD . # 将所有档案都checkout 出来(最后一次commit 的版本), 注意, 若有修改的档案都会被还原到上一版. (git checkout -f 亦可)
git checkout xxxx . # 将所有档案都checkout 出来(xxxx commit 的版本, xxxx 是commit 的编号前四码), 注意, 若有修改的档案都会被还原到上一版.
git checkout -- * # 恢复到上一次Commit 的状态(* 改成档名, 就可以只恢复那个档案)
Git diff
git diff master # 与Master 有哪些资料不同
git diff --cached # 比较staging area 跟本来的Repository
git diff tag1 tag2 # tag1, 与tag2 的diff
git diff tag1:file1 tag2:file2 # tag1, 与tag2 的file1, file2 的diff
git diff # 比较目前位置与staging area
git diff --cached # 比较staging area 与Repository 差异
git diff HEAD # 比较目前位置与Repository 差别
git diff new-branch # 比较目前位置与branch(new-branch) 的差别
git diff --stat
Git Tag
git tag v1 ebff # log 是commit ebff810c461ad1924fc422fd1d01db23d858773b 的内容, 设定简短好记得Tag: v1
git tag 中文ebff # tag 也可以下中文, 任何文字都可以
git tag -d 中文# 把tag=中文删掉
Git log
git log # 将所有log 秀出
git log --all # 秀出所有的log (含branch)
git log -p # 将所有log 和修改过得档案内容列出
git log -p filename # 将此档案的commit log 和修改档案内容差异部份列出
git log --name-only # 列出此次log 有哪些档案被修改
git log --stat --summary # 查每个版本间的更动档案和行数
git log filename # 这个档案的所有log
git log directory # 这个目录的所有log
git log -S'foo()' # log 里面有foo() 这字串的.
git log --no-merges # 不要秀出merge 的log
git log --since="2 weeks ago" # 最后这2周的log
git log --pretty=oneline # 秀log 的方式
git log --pretty=short # 秀log 的方式
git log --pretty=format:'%h was %an, %ar, message: %s'
git log --pretty=format:'%h : %s' --graph # 会有简单的文字图形化, 分支等.
git log --pretty=format:'%h : %s' --topo-order --graph # 依照主分支排序
git log --pretty=format:'%h : %s' --date-order --graph # 依照时间排序
Git show
git show ebff # 查log 是commit ebff810c461ad1924fc422fd1d01db23d858773b 的内容
git show v1 # 查tag:v1 的修改内容
git show v1:test.txt # 查tag:v1 的test.txt 档案修改内容
git show HEAD # 此版本修改的资料
git show HEAD^ # 前一版修改的资料
git show HEAD^^ # 前前一版修改的资料
git show HEAD~4 # 前前前前一版修改的资料
Git reset 还原
git reset --hard HEAD # 还原到最前面
git reset --hard HEAD~3
git reset --soft HEAD~3
git reset HEAD filename # 从staging area 状态回到unstaging 或untracked (档案内容并不会改变)
Git grep
git grep "te" v1 # 查v1 是否有"te" 的字串
git grep "te" # 查现在版本是否有"te" 的字串
Git stash 暂存
git stash # 丢进暂存区
git stash list # 列出所有暂存区的资料
git stash pop # 取出最新的一笔, 并移除.
git stash apply # 取出最新的一笔stash 暂存资料. 但是stash 资料不移除
git stash clear # 把stash 都清掉
Git merge 合并
git merge
git merge master
git merge new-branch
下述转载自: ihower 的Git 版本控制系统(2) 开branch 分支和操作远端repo.x
Straight merge 预设的合并模式,会有全部的被合并的branch commits 记录加上一个merge-commit,看线图会有两条Parents 线,并保留所有commit log。
Squashed commit 压缩成只有一个merge-commit,不会有被合并的log。SVN 的merge 即是如此。
cherry-pick 只合并指定的commit
rebase 变更branch 的分支点:找到要合并的两个branch 的共同的祖先,然后先只用要被merge 的branch 来commit 一遍,然后再用目前branch 再commit 上去。这方式仅适合还没分享给别人的local branch,因为等于砍掉重练commit log。
指令操作
git merge <branch_name> # 合并另一个branch,若没有conflict 冲突会直接commit。若需要解决冲突则会再多一个commit。
git merge --squash <branch_name> # 将另一个branch 的commit 合并为一笔,特别适合需要做实验的fixes bug 或new feature,最后只留结果。合并完不会帮你先commit。
git cherry-pick 321d76f # 只合并特定其中一个commit。如果要合并多个,可以加上-n 指令就不会先帮你commit,这样可以多pick几个要合并的commit,最后再git commit 即可。
Git blame
git blame filename # 关于此档案的所有commit 纪录
Git 还原已被删除的档案
git ls-files -d # 查看已删除的档案
git ls-files -d | xargs git checkout -- # 将已删除的档案还原
Git 维护
git gc # 整理前和整理后的差异, 可由: git count-objects 看到.
git fsck --full
Git revert 资料还原
git revert HEAD # 回到前一次commit 的状态
git revert HEAD^ # 回到前前一次commit 的状态
git reset HEAD filename # 从staging area 状态回到unstaging 或untracked (档案内容并不会改变)
git checkout filename # 从unstaging 状态回到最初Repository 的档案(档案内容变回修改前)
Git Rollback 还原到上一版
git reset --soft HEAD^
编辑+ git add filename
git commit -m 'rollback'
以下与远端Repository 相关
Git remote 维护远端档案
git remote
git remote add new-branch http://git.example.com.tw/project.git # 增加远端Repository 的branch(origin -> project)
git remote show # 秀出现在有多少Repository
git remote rm new-branch # 删掉
git remote update # 更新所有Repository branch
git branch -r # 列出所有Repository branch
抓取/ 切换Repository 的branch
git fetch origin
git checkout --track -b reps-branch origin/reps-branch # 抓取reps-branch, 并将此branch 建立于local 的reps-branch
删除Repository 的branch
git push origin :heads/reps-branch
git config
git config --list
git config user.name
git config user.name "username"
git config --global user.name "username"
相关推荐
内容概要:该文档介绍了一个用C++编写的控制台应用程序,主要功能是在新年来临之际展示倒计时、播放音符以及渲染烟花效果,最终以艺术字体显示新年祝福语。具体实现了粒子系统来模拟烟花绽放,并定义了不同形状(如“2025”)由小点组成的图像,再逐帧更新显示,营造烟火燃放的视觉冲击力。此外还有通过 Beep 函数发出不同频率的声音以配合倒计时刻度,同时加入了输入姓名和许愿的功能增加互动感。 适用人群:熟悉C/C++语言基础的学生群体及开发者。 使用场景及目标:适用于希望通过生动有趣的小项目加深对控制台操作的理解的学习者;也可以作为一个简单有趣的案例用于节日庆祝活动中。 其他说明:由于使用了许多特定于 Windows 平台的API函数,比如 Beep(), SetConsoleTextAttribute() 和 GetStdHandle(), 本程序仅能在 Windows 上运行良好。并且涉及到了较多关于粒子系统和声音处理的知识点,在教学过程中可以借此讲解一些图形渲染的基本原理和音频处理方法。
儿歌、手指谣、律动.docx
【文章链接:https://blog.csdn.net/2403_86849624/article/details/145739426?spm=1001.2014.3001.5502】基于 MSP430 微控制器的环境监测系统的设计与实现。该系统集成了温湿度、光照度、烟雾浓度以及 PM2.5 浓度等多参数的监测功能,具备数据显示、阈值设置和报警等功能。通过硬件电路与软件程序的协同工作,系统能够实时、准确地获取环境信息,并为用户提供直观的数据展示和有效的预警。文中深入探讨了系统的硬件选型、电路设计、软件编程思路及关键代码实现,经实际测试验证,该系统运行稳定、性能可靠,在环境监测领域具有一定的应用价值。关键词:MSP430;环境监测;传感器;数据处理 随着工业化进程的加速和人们生活水平的提高,环境质量对人类健康和社会发展的影响愈发显著。准确、实时地监测环境参数,对于预防环境污染、保障人体健康以及推动可持续发展至关重要。
基于COMSOL仿真的电磁超声压电接收技术在铝板裂纹检测中的应用研究,COMSOL模拟:电磁超声压电接收技术在铝板裂纹检测中的应用,comsol电磁超声压电接收EMAT 在1mm厚铝板中激励250kHz的电磁超声在200mm位置处设置一个深0.8mm的裂纹缺陷,左端面设为低反射边界。 在85mm位置处放置一个压电片接收信号,信号如图3所示,三个波分别为始波,裂纹反射波(S0模态)和右端面回波(S0)。 ,comsol;电磁超声;压电接收;EMAT;裂纹缺陷;信号接收;波;始波;S0模态;右端面回波,电磁超声检测技术:裂纹缺陷定位与信号分析
MATLAB环境中基于PSO算法的机器人路径规划系统:可视化界面下的障碍物自定义与终点规划,MATLAB实现PSO算法的机器人路径规划系统:支持自定义障碍物、起点终点的可视化界面操作,基于MATLAB的粒子群优化(PSO)算法的机器人路径规划,可视化界面,可自定义障碍物,起点和终点。 ,MATLAB; 粒子群优化(PSO)算法; 机器人路径规划; 可视化界面; 自定义障碍物; 起点和终点,MATLAB PSO算法机器人路径规划与可视化界面
五电平无刷直流电机BLDC矢量控制仿真模型研究:转速稳定、多电平可调参数的Matlab Simulink模型应用,五电平无刷直流电机BLDC矢量控制仿真模型研究:转速稳定、多电平可调参数的Matlab Simulink模型应用分析,五电平无刷直流电机BLDC矢量控制仿真模型,给定转速1000r min,运行良好; 三电平,两电平均可做,可调参数; matlab simulink模型 ,五电平BLDC矢量控制; 仿真模型; 1000r_min; 三电平控制; 可调参数; Matlab_Simulink模型。,五电平BLDC矢量控制仿真模型:三电平可调参数,1000r/min良好运行,Matlab Simulink实现
VSG预同步控制与电流双环控制的Matlab仿真模型研究及电力电子入门指南,基于Matlab的VSG预同步控制仿真模型:涵盖并网逆变器、VSG控制及电流双环管理等多模块研究参考文献详实电力电子仿真入门指南,VSG预同步控制matlab仿真模型 主要模块: 并网逆变器+VSG控制+预同步控制+电流电流双环控制 锁相环、三相准PR控制、PWM。 并附带参考文献,内容详实,适合电力电子入门仿真参考。 ,VSG预同步控制; MATLAB仿真模型; 并网逆变器; VSG控制; 预同步控制; 电流双环控制; 锁相环; 三相准PR控制; PWM; 参考文献。,Matlab仿真模型:VSG预同步控制及多模块协同仿真研究
WIFI密码查看器支持Windows系统,简单实用,欢迎下载
1998-2022年各地级市产业结构高级化数据(含原始数据+计算过程+结果) 1、时间:1998-2022年 2、指标:第二产业占比、第三产业占比、产业结构高级化 3、来源:城市统计NJ 4、计算说明:产业结构高级化=第三产业占比/第二产业占比 5、范围:290+地级市 6、缺失情况:缺失情况与年鉴一致,表内附有年鉴国内生产总值构成(三次产业占比)原始数据,以2022年地级市名单进行统计整理,2017年年鉴未统计全市层面数据,为市辖区数据
Skyline TerraExplorer Pro 5.1.3
1、文件内容:v4l-utils-0.9.5-4.el7.rpm以及相关依赖 2、文件形式:tar.gz压缩包 3、安装指令: #Step1、解压 tar -zxvf /mnt/data/output/v4l-utils-0.9.5-4.el7.tar.gz #Step2、进入解压后的目录,执行安装 sudo rpm -ivh *.rpm 4、更多资源/技术支持:公众号禅静编程坊
项目工程资源经过严格测试运行并且功能上ok,可实现复现复刻,拿到资料包后可实现复现出一样的项目,本人系统开发经验充足(全栈全领域),有任何使用问题欢迎随时与我联系,我会抽时间努力为您解惑,提供帮助 【资源内容】:包含源码+工程文件+说明(如有)等。答辩评审平均分达到96分,放心下载使用!可实现复现;设计报告也可借鉴此项目;该资源内项目代码都经过测试运行;功能ok 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 【提供帮助】:有任何使用上的问题欢迎随时与我联系,抽时间努力解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 下载后请首先打开说明文件(如有);整理时不同项目所包含资源内容不同;项目工程可实现复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用
风力永磁同步发电机设计及仿真分析:Maxwell电磁仿真在1.5兆瓦风力发电机中的应用与工况研究,基于Maxwell电磁仿真的1.5兆瓦风力永磁同步发电机设计与工况分析,1.5兆瓦风力发电机 maxwell电机电磁仿真 风力永磁同步发电机设计,分析及工况分析 ,关键词:1.5兆瓦风力发电机; Maxwell电机电磁仿真; 永磁同步发电机设计; 永磁同步发电机分析; 工况分析。,Maxwell电机电磁仿真:风力永磁同步发电机设计与工况分析
XChart插件,用来做图表,但是图表不能做出很好看的样式
基于FVC2002数据集的MATLAB指纹识别系统研究与应用,基于MATLAB的FVC2002指纹数据集识别系统研究与应用,基于MATLAB的指纹识别系统 数据集为FVC2002指纹数据集 ,基于MATLAB; 指纹识别系统; FVC2002指纹数据集,基于MATLAB的FVC2002指纹识别系统
内容概要:本文由甲子光年智库发布,探讨了人工智能发展的拐点以及DeepSeek作为AI技术变革标志性产品的现状和前景。文中指出,人工智能的发展经历了从技术驱动到需求驱动的战略转变,正处于第三阶段向第四阶段过渡时期。DeepSeek通过对算力的极致优化,不仅展示了性价比极高的训练路径,还引领了算力效率的新拐点。2025年起发布的AI模型逐渐减少参数量,以支持更多场景下的高效部署,特别是移动终端和边缘计算领域。与此同时,以深度强化学习为核心的R1训练框架与非Transformer架构下的液态神经网络模型(LFM)共同开启了新一轮算法革新浪潮。 适用人群:对AI发展趋势感兴趣的行业从业者和技术爱好者。 使用场景及目标:用于了解AI技术的当前瓶颈与发展方向,把握算法创新、算力优化等方面的具体进展。适用于投资者研判行业趋势、技术人员跟进最新研究成果。 其他说明:文章详细阐述了DeepSeek的产品特点与市场反响,以及在全球AI治理框架下各国政府的态度变化。值得注意的是,DeepSeek的性价比优势促进了普惠AI的发展,使更多的中小企业和个人开发者获得了参与高水平AI项目的可能性。此外,文章还提及了美国政府内部关于AI政策的变化情况,揭示了中美两国在未来科技竞争格局下的潜在博弈态势。
基于栅格法的D*算法路径规划在Matlab中的实现与注释:自定义起点、终点与障碍物位置,基于D*算法和栅格法的Matlab路径规划:自定义地图与避障路径搜索,D*算法路径规划 Matlab路径规划 栅格法 可自行更改绘制栅格地图,自定义起始点目标点位置、未知障碍物位置 遭遇障碍物,重新搜索路径! matlab实现 详细注释 仅提供代码 ,D*算法;Matlab路径规划;栅格法;自定义起始点目标点;未知障碍物;重新搜索路径;matlab实现;详细注释,Matlab实现D*算法栅格路径规划:自定义障碍与详细注释版
基于51单片机protues仿真的搬运机器人设计(仿真图、源代码) 流程说明: 1,一上电,先通过按按键设置物块的高度和体积 2,注意,物块高度或者体积只要有其中一个为0时,不能开始搬运 3,按下开始搬运按键,即开始搬运, 流程是 机械臂先把物块抓取到机器车上, 机械臂减速 机器车带着物块前往目的地 机器车减速 机械臂把物块放下来 机械臂减速 机器车回到物块堆积处(此时机器车是空车) 机器车减速 蜂鸣器响,提示本次搬运已经完成 4,这时候按下机器复位按键,开始下一次设置物块参数和搬运 搬运物块完成提示模块 第一行显示的是物块的高度和机器车与物块堆积处的距离 第二行显示的是物块的体积或者直径或者质量
航天模拟器文件、蓝图、代码
四策略融合的SSA优化BP神经网络分类预测研究——MISSA-BP框架下的收敛性能与实验结果分析,SSA优化BP神经网络分类预测的MISSA-BP模型:四策略融合提升算法性能的实证研究,四策略融合改进SSA优化BP神经网络分类预测(MISSA-BP) 改进点文献 目前相关分类文章数量中外都不是很多。 改进创新足,抓紧入手抓紧发个人感觉英文开源中文核心都不是问题。 改进点:中文注释清晰 融合spm映射、自适应-正余弦算法、levy机制、步长因子动态调整4种策略改进 改进后效果非常好 收敛速度和收敛精度极少代数即完成收敛,显示均方误差。 最大迭代次数:500(根据具体图像可调) 独立运行次数:30 初始种群数量:30 测试函数对比算法:SSA,CSSA,TSSA 对比效果和测试函数(一共22个函数只列出了部分)函数形状均给出,有需要,改进部位有详细说明文档(附带改进参考文献) 代码注释明确,替数数据集即可使用,该价格只是代码 ,关键词: 1. MISSA-BP 优化; 2. SSA 神经网络分类预测; 3. 四策略融合; 4. 文献改进点; 5. 分类文章数量; 6. 改进创新; 7.