git命令汇总
Posted Jocelin47
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了git命令汇总相关的知识,希望对你有一定的参考价值。
git init
初始化一个仓库,生成一个隐藏的.git文件夹
git status
查看文件状 — 可以通过【 git add +文件 】命令将文件设为就绪,就绪了文件会变绿,没有add的文件是红色的
当前文件状态为untracked filed,如果对当前提交后在修改就是modified状态
git add < filename >
git add main.c
git add .
(如果当前目录下修改的文件全部暂存到status中 )
git commit -m < message > [提交文件]
message为需要注释为这次提交修改
git log [查看日志 ]
查看日志
每次commit提交都会有一个唯一的哈希值
- 文件状态的名字
此时修改后的文件就是modified的状态了
因此文件状态是有名字的:
如果staged之前的是未创建的那就是untracked,如果是创建过的且之前commit过的文件那就是unmodifed的,如果修改了这个unmodifed的文件那他的状态就是modifed的状态
git reset < filename > [回退文件状态]
将绿色就绪的文件改为红色
git命令设置别名alias
windows下在git安装目录可以修改文件设置
每次直接通过ad命令直接add所有的文件
git reset < commit ID > [回退版本]
如果我当前提交了很多次,我想回到之前提交的版本 可以通过git log查看之前commit的ID 也就是哈希值
例如我添加了b.c,我现在commit提交了新的版本,但是我想回到第一次提交时的状态
此时我们使用git rest + 哈希值 + hard
git reset 02a716d10c3340712c98fc180639c6e98bcd38a8 --hard
这样我们的代码就回退到第一次的版本了
git reflog [查看历史操作]
如果上面撤回的操作你后悔了,你又想回到原来最新的状态,查看所有的历史操作
通过
bash git reset + 哈希值 --hard
这里必须加hard才能把原来的代码找回来,如果不加hard没有反应
这里的哈希值变成7为的了,其实只要前7为就可以唯一的确定
- git reset的模式
相当于回退的文件,变更他回退后的状态
git checkout -b < name > < template > [创建分支]
前面创建了很多的commit后的版本后,但是多了之后就记不住了 可以创建分支
- name为新分支的名字
- template:以哪个分支或者commit为模版,如果这个不写则完全复制主分支,如下图所示
git checkout < 分支名 > [切换分支]
通过git checkout master 切换主分支 通过git log是查看不到子分支的commit的
并且此时目录下是没有c.c文件的,再切回子分支后,c.c又会出现
git branch [查看所有的分支]
git merge[合并其他分支的代码]
分支的变更
git commit -b 1.0.0 主管创建了一个1.0.0的分支
git checkout -b bc-a 员工A
git checkout -b bc-b 员工B
小b完成了代码在merge.c中更改了代码完成的操作
git add .
git checkout -m “b finish”
git checkout bc-a 切换到A
也在merge.c中更改了代码
git add .
git commit -m “a finish”
主要想要把A、B的代码进行合并在一起
git checkout 1.0.0
git merge bc-a
git merge bc-b 将B的代码合并过后就会产生冲突
弹出一个vscode编译器的窗口提示信息。
git commit -m “解决冲突”
A推送bc-a分支到远程代码仓库,
B通过fetch拉取到本地仓库
如果A修改了代码,push到远程仓库,那么B如何让新的变更到自己可以git fetch 然后 merge远程分支 更方便的代码是git pull
变基rebase,即重新排列base,base指的是commit不同次的提交:
以上是关于git命令汇总的主要内容,如果未能解决你的问题,请参考以下文章