Git基础

Git基础


获取项目的git仓库

从当前目录初始化

在当前项目的目录先初始化git,然后将需要使用git管理的添加进去。

  1. $ git init
  2. $ git add *.c
  3. $ git conmmit -m 'initial project version'

从现有的仓库克隆

使用git clone url [dirName] 来将远端项目克隆至名为dirName的文件夹下,文件夹若缺省则为拷贝至当前目录,且文件夹名与项目名一样。
Git支持许多数据传输协议,可以是git://协议,http(s)://或者user@server:/path.git表示的SSH传输协议。

记录每次更新到仓库

使用Git管理的工作目录下的文件的两种状态:已跟踪(tracked files),未跟踪(untracked files),已跟踪的文件是纳入Git管理的文件,只有已跟踪的文件才有之前所说的文件的三种状态。

检查当前文件状态

当前目录下执行git status,输出的提示相当详细,包括该使用何种命令应对不同状态的文件。

跟踪新文件

执行git add file ,如果添加的是目录,则需要递归目录下的所有文件。执行之后,文件的 此时此刻 的版本将被放到暂存区,等待下次提交。

暂存已修改文件

运行git add file ,将本次修改保存到暂存区(git add这一命令根据文件状态的不同,有多种用途)。
对于已经暂存了的文件又做出修改,那么文件又变成已修改的状态,需要再次使用git add来暂存文件,否则暂存区存放的只是上次修改的文件。

忽略某些文件

在工作目录下新建.gitignore这一文件,将所有需要无需纳入Git管理,也不希望总是提示为未跟踪的文件列入,来忽略这些文件。
.gitignore文件的格式规范
- 所有空行或以注释号#开头的行都会被git忽略;
- 可以使用标准的glob模式匹配;
- 匹配模式最后跟反斜杠(/)说明要忽略的是目录;
- 要忽略指定模式以外的文件或目录,可以在模式匹配前加惊叹号(!)取反。

注:glob模式是指shell所使用的简化了的正则表达式。

  1. # 此为注释 – 将被 Git 忽略
  2. *.a # 忽略所有 .a 结尾的文件
  3. !lib.a # 但 lib.a 除外
  4. /TODO # 仅仅忽略项目根目录下的 TODO 文件,不包括 subdir/TODO
  5. build/ # 忽略 build/ 目录下的所有文件
  6. doc/*.txt # 会忽略 doc/notes.txt 但不包括 doc/server/arch.txt

查看已暂存和未暂存的更新

  • git diff 比较工作目录中当前文件和暂存区快照之间的差异。及已修改的和已暂存的文件的差异。
  • git diff --cached或高版本的Git可以使用git diff --staged来查看已暂存的文件和上次提交时的快照之间的差异。

提交更新

每次提交之前,先用git status检查看是否所有文件已经暂存,然后用git commit提交更新。这种方式会打开文本编辑器,第一行为空,在这里写上更新说明。可以使用-v参数,将修改差异的每一行都包含到注释中。也可已使用-m参数,git commit -m "the description of the update",直接协商提交说明。

跳过使用暂存区,直接提交更新

git commit -a,Git自动把已跟踪的文件暂存起来,一并提交,跳过git add操作。

移除文件

将已跟踪的文件从工作目录中删除:git rm file,如果删除之前修改过并且已经放到暂存区的话,需要使用强制删除选项-f,以防误删文件后丢失修改的内容。
将文件从Git仓库中移除但是仍保留在工作目录中:git rm --cached file,然后在.gitingnore文件中补上来忽略。
git rm后可以跟文件名货目录名,也可使用glob模式匹配。

  1. git rm log/\*.log
  2. git rm \*~

如上,第一行删除log/目录下扩展名为.log的文件,第二行递归删除当前目录下
以及其子目录总所有以~结尾的文件。

移动文件(重命名文件)

git mv fileFrom fileTo
这一条命名相当于:

  1. mv *fileFrom* *fileTo*
  2. git rm *fileFrom*
  3. git add *fileTo*

查看提交历史

git log

一些常用参数
-p 按补丁格式显示每个更新之间的差异。
--stat 显示每次更新的文件修改统计信息。
--shortstat 只显示 --stat 中最后的行数修改添加移除统计。
--name-only 仅在提交信息后显示已修改的文件清单。
--name-status 显示新增、修改、删除的文件清单。
--abbrev-commit 仅显示 SHA-1 的前几个字符,而非所有的 40 个字符。
--relative-date 使用较短的相对时间显示(比如,“2 weeks ago”)。
--graph 显示 ASCII 图形表示的分支合并历史。
--pretty 使用其他格式显示历史提交信息。可用的选项包括 oneline,short,full,fuller 和 format(后跟指定格式)。

撤销操作

修改最后一次提交
  • 修改提交信息:git commit --amend
  • 提交忘记暂存的某些文件:补上暂存操作,再使用--amend提交。
取消已暂存的文件

git reset HEAD file
在运行git status时,对于已经提交的文件会有该操作提示,所以不需要死记硬背。

取消对文件的修改

git checkout -- file
同样在运行git status时会有提示。该操作把已修改的未保存到暂存区的文件恢复到之前的版本,所有的修改内容将丢失。

注意:这样的操作有点危险,因为修改的内容将丢失。如果只是想回退到上一版本,保存当前修改,可以使用stashing和分支来处理。
记住,任何已经提交到Git的都可以被恢复。

远程仓库的使用

打标签

技巧和窍门

自动完成

可以像使用命令行自动补全那样按tab键两次在输入git命令时来输出补全提示。
如果使用的时Bash Shell,可以使用Git提供的自动补全脚本。

Git命令别名

例如:git config --global alias.ci commit
则 git ci=git commit

【完美复现】面向配电网韧性提升的移动储能预布局与动态调度策略【IEEE33节点】(Matlab代码实现)内容概要:本文介绍了基于IEEE33节点的配电网韧性提升方法,重点研究了移动储能系统的预布局与动态调度策略。通过Matlab代码实现,提出了一种结合预配置和动态调度的两阶段优化模型,旨在应对电网故障或极端事件时快速恢复供电能力。文中采用了多种智能优化算法(如PSO、MPSO、TACPSO、SOA、GA等)进行对比分析,验证所提策略的有效性和优越性。研究不仅关注移动储能单元的初始部署位置,还深入探讨其在故障发生后的动态路径规划与电力支援过程,从而全面提升配电网的韧性水平。; 适合人群:具备电力系统基础知识和Matlab编程能力的研究生、科研人员及从事智能电网、能源系统优化等相关领域的工程技术人员。; 使用场景及目标:①用于科研复现,特别是IEEE顶刊或SCI一区论文中关于配电网韧性、应急电源调度的研究;②支撑电力系统在灾害或故障条件下的恢复力优化设计,提升实际电网应对突发事件的能力;③为移动储能系统在智能配电网中的应用提供理论依据和技术支持。; 阅读建议:建议读者结合提供的Matlab代码逐模块分析,重点关注目标函数建模、约束条件设置以及智能算法的实现细节。同时推荐参考文中提及的MPS预配置与动态调度上下两部分,系统掌握完整的技术路线,并可通过替换不同算法或测试系统进一步拓展研究。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值