5分钟 学会Git

Git 是最近这几年流行的源代码管理工具。

优点:分布式管理 ,去中心化,离线提交本地提交,可以自己代码Commit 到本地,而后在Push 合并,fork 别人的代码,然后自己可以闭门造车修改。

pull-request 工作流将 code review 强制纳入日常开发流程,而且足够简单


优点:难学,概念多,Eclipse 上面的egit 太二,提交默认针对是整个项目,而某个目录。

SVN:集中式管理 


开玩笑的一句话:Git 能离线使用只是个传说,你仍然需要联网搜索该用哪个命令传什么参数。

Git 原理和概念:

1.git 暂存区(Index,各种修改文件都可以放入暂存区) git add 将文件内容存入blob 对象,git commit 将index 生成tree 对象

2.Git用blob对象来存储文件内容,用tree对象存储目录里的文件名。




前置条件:

1.配置SSH,SSH好处就是提供可以信任计算机的认证,而无需通过密码。简单来说,每次下载东西,你再也不用输入密码了。

2.已经安装Git 的命令行


1.从Git拖项目,如

$ git clone git@github.com:spring/spring.git


2.查看本地和远程的代码的区别:

$ git status

On branch develop

Your branch is up-to-date with 'origin/develop'.


nothing to commit, working directory clean


3.修改文件文件后,提交到服务器的三个步骤。

3.1  指明要增加的文件,代码当前文件夹

$git add . 

(git add 的意思是讲文件添加到暂存区 index)

$git add XXX.java

3.2 commit 到本地,commit 到github之前必须要Commit 到本地。( -m 代码注释 ,引号“ ”是注释的内容)

$git commit -m "test it "

3.3上传到服务器

$git push 

到此你已经成功把XXX.java 文件成功提交到服务器。


4.拖最新服务器的代码,改代码之前,最后先pull 一下,免得要慢慢合并

$git pull 


5.本地Commit 了3个,领先服务器3个版本,但是只想提交一个版本。

$git reset /origin/develop

5.1单个文件覆盖

$git checkou --  文件




然后再

5.1 git add .

5.2 git commit -m "test again"

5.3.git push 

大功告成


6.要用远程服务的文件,全覆盖本地的文件,相当于(Replace All ),本地修改会全无,你再也找不到了。

如果有修改,你用了,是男人的不要哭了,你可以熬夜重敲一遍,颤抖吧骚年。

git reset origin/develop --hard

HEAD is now at 489a28b hello

或者

$git checkout -- a


7. 注释里面的#3,能和github 里面的issue 结合起来。

git commit -m “#3 “   


8.查看日志 

git log 


9.查看分支

$git branch --all  
# 默认只有master分支,所以会看到如下两个分支
# master[本地主分支] origin/master[远程主分支]
# 新克隆下来的代码默认master和origin/master是关联的,也就是他们的代码保持同

10.在分支上开发

git checkout dev  # 切换到dev分支进行开发
# 开发代码之后,我们有两个选择
# 第一个:如果功能开发完成了,可以合并主分支
git checkout master  # 切换到主分支
git merge dev  # 把dev分支的更改和master合并
git push  # 提交主分支代码远程
git checkout dev  # 切换到dev远程分支
git push  # 提交dev分支到远程
# 第二个:如果功能没有完成,可以直接推送
git push  # 提交到dev远程分支
# 注意:在分支切换之前最好先commit全部的改变,除非你真的知道自己在做什

11.删除分支

git push origin :dev  # 删除远程dev分支,危险命令哦
# 下面两条是删除本地分支
git checkout master  # 切换到master分支
git branch -d dev  # 删除本地dev分支

12.其它高级功能

git rebase 

git rebase origin/dev  # 将你的commits移到的末尾

13. 产看文件的修改
$ git diff pom.xml 

14.git add -i 

$ git add -i

           staged     unstaged path


15.新增加的文件不能通过git commit -a命令添加到暂存区域,还得单独运行git add命令




*** Commands ***

  1: status   2: update   3: revert   4: add untracked

  5: patch   6: diff   7: quit   8: help


8.合并???我也还不知道怎么合并。。。。

 

REF:

http://git-scm.com/book/en/v2

https://www.atlassian.com/git/tutorials/comparing-workflows

https://www.atlassian.com/git/tutorials/comparing-workflows/forking-workflow

http://www.zhihu.com/question/19946553

https://www.youtube.com/watch?v=4XpnKHJAok8


问题:

1.git 之前为什么要先add.

2.git 怎么对某个目录操作,而暂时先不管其它的。(SVN会在每个目录设置一个.svn 的文件夹)


代码下载地址: https://pan.quark.cn/s/bc087ffa872a "测控电路课后习题详解"文件.pdf是一份极具价值的学术资料,其中系统地阐述了测控电路的基础理论、系统构造、核心特性及其实际应用领域。 以下是对该文献的深入解读和系统梳理:1.1测控电路在测控系统中的核心功能测控电路在测控系统的整体架构中扮演着不可或缺的角色。 它承担着对传感器输出信号进行放大、滤除杂音、提取有效信息等关键任务,并且依据测量与控制的需求,执行必要的计算、处理与变换操作,最终输出能够驱动执行机构运作的指令信号。 测控电路作为测控系统中最具可塑性的部分,具备易于放大信号、转换模式、传输数据以及适应多样化应用场景的优势。 1.2决定测控电路精确度的关键要素影响测控电路精确度的核心要素包括:(1)噪声与干扰的存在;(2)失调现象与漂移效应,尤其是温度引起的漂移;(3)线性表现与保真度水平;(4)输入输出阻抗的特性影响。 在这些要素中,噪声干扰与失调漂移(含温度效应)是最为关键的因素,需要给予高度关注。 1.3测控电路的适应性表现测控电路在测控系统中展现出高度的适应性,具体表现在:* 具备选择特定信号、灵活实施各类转换以及进行信号处理与运算的能力* 实现模数转换与数模转换功能* 在直流与交流、电压与电流信号之间进行灵活转换* 在幅值、相位、频率与脉宽信号等不同参数间进行转换* 实现量程调整功能* 对信号实施多样化的处理与运算,如计算平均值、差值、峰值、绝对值,进行求导数、积分运算等,以及实现非线性环节的线性化处理、逻辑判断等操作1.4测量电路输入信号类型对电路结构设计的影响测量电路的输入信号类型对其电路结构设计产生显著影响。 依据传感器的类型差异,输入信号的形态也呈现多样性。 主要可分为...
(IHAOAVOABPvsAOBPvsAVOABPvsPSOBP)非洲秃鹫融合天鹰优化BP天鹰优化BP非州秃鹫BP粒子群(Matlab代码实现)内容概要:本文档主要围绕多种智能优化算法在不同工程领域的应用展开,重点介绍了非洲秃鹫优化算法(AVOA)、天鹰优化算法(AO)与BP神经网络的融合改进,并与其他经典算法如粒子群优化(PSO)进行对比分析。所有案例均提供Matlab代码实现,涵盖电力系统优化、路径规划、微电网调度、无人机控制、信号处理等多个方向,强调算法的科研复现能力与实际仿真价值。文档还展示了丰富的技术服务体系,涉及机器学习、深度学习、路径规划、通信与电力系统等多个前沿领域。; 适合人群:具备一定Matlab编程基础,从事科研工作或工程仿真的研究生、高校教师及企业研发人员,尤其适用于从事智能优化算法研究与应用的相关技术人员。; 使用场景及目标:①用于学术论文复现,特别是SCI/EI期刊中关于优化算法的实验部分;②为电力系统、无人机、储能调度等领域提供算法仿真技术支持;③帮助研究人员快速掌握多种智能算法的实现方法并进行性能对比。; 阅读建议:建议结合文档提供的网盘资源下载完整代码,按照目录顺序逐步学习,重点关注算法原理与Matlab实现的结合方式,同时可将文中案例作为自身课题的参考模板进行二次开发与创新。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值