git学习10-强制删除未合并的分支
软件开发中,总有无穷无尽的新的功能要不断添加进来。
添加一个新功能时,你肯定不希望因为一些实验性质的代码,把主分支搞乱了,所以,每添加一个新功能,最好新建一个feature分支,在上面开发,完成后,合并,最后,删除该feature分支。
现在,你终于接到了一个新任务:开发代号为Vulcan的新功能,该功能计划用于下一代星际飞船。
于是准备开发:
2CARYS4 /e/pyc_study (dev)
□□ git branch
* dev
feature2
master
2CARYS4 /e/pyc_study (dev)
□□ git switch feature2
Switched to branch 'feature2'
2CARYS4 /e/pyc_study (feature2)
□□ git status
On branch feature2
nothing to commit, working tree clean
2CARYS4 /e/pyc_study (feature2)
□□ ls
main.py README.md
2CARYS4 /e/pyc_study (feature2)
□□ vim vulcan.py
2CARYS4 /e/pyc_study (feature2)
□□ python vulcan.py
老夫聊发少年狂,左牵黄,右擎苍。锦帽貂裘千骑卷平岗...
2CARYS4 /e/pyc_study (feature2)
□□
开发完毕
2CARYS4 /e/pyc_study (feature2)
□□ git add vulcan.py
warning: LF will be replaced by CRLF in vulcan.py.
The file will have its original line endings in your working directory
2CARYS4 /e/pyc_study (feature2)
□□ git status
On branch feature2
Changes to be committed:
(use "git restore --staged <file>..." to unstage)
new file: vulcan.py
2CARYS4 /e/pyc_study (feature2)
□□ git commit -m "add feature2 vulcan"
[feature2 373f194] add feature2 vulcan
1 file changed, 2 insertions(+)
create mode 100644 vulcan.py
2CARYS4 /e/pyc_study (dev)
□□
切回dev
,准备合并:
2CARYS4 /e/pyc_study (feature2)
□□ git switch dev
Switched to branch 'dev'
2CARYS4 /e/pyc_study (dev)
□□
一切顺利的话,feature分支和bug分支是类似的,合并,然后删除。
但是!
就在此时,接到上级命令,因经费不足,新功能必须取消!
虽然白干了,但是这个包含机密资料的分支还是必须就地销毁:
2CARYS4 /e/pyc_study (dev)
□□ git branch -d feature2
error: The branch 'feature2' is not fully merged.
If you are sure you want to delete it, run 'git branch -D feature2'.
2CARYS4 /e/pyc_study (dev)
□□
销毁失败。Git友情提醒,feature-vulcan ( feature2 )
分支还没有被合并,如果删除,将丢失掉修改,如果要强行删除,需要使用大写的-D
参数。。
现在我们强行删除:
2CARYS4 /e/pyc_study (dev)
□□ git branch -D feature2
Deleted branch feature2 (was 373f194).
2CARYS4 /e/pyc_study (dev)
□□ git branch
* dev
master
2CARYS4 /e/pyc_study (dev)
□□
终于删除成功!
小结
开发一个新feature,最好新建一个分支;
如果要丢弃一个没有被合并过的分支,可以通过git branch -D <name>
强行删除。