Git学习笔记3

Git分支管理:

先来考虑一个问题: 开发者A开发软件的某一个功能模块, 还没有开发完成,但害怕进度丢失就提交。假设另一位开发者B并不知道A没有完成, 而直接使用了A开发的文件,这造成了问题。

解决方法: **开发者A创建一个属于自己的分支,这个分支只属于A,不会影响其他人。**开发完成后,合并到项目主分支即可。

分支可以看做是平行空间:

查看分支:

默认只有一个分支,前面*代表为当前分支。

查看分支:

创建分支:

bash 复制代码
[root@git-server GitTest]# git branch dev
[root@git-server GitTest]#
[root@git-server GitTest]# git branch
  dev
* master

切换分支:

使用 git checkout 分支名 来切换分支。

bash 复制代码
[root@git-server GitTest]# git checkout dev
Switched to branch 'dev'
[root@git-server GitTest]#
[root@git-server GitTest]# git branch
* dev
  master

合并分支:

1)在dev分支上新开发了一个代码文件,添加并提交。

bash 复制代码
[root@git-server GitTest]# echo "New feature" >> 5.py
[root@git-server GitTest]#
[root@git-server GitTest]# git add 5.py
[root@git-server GitTest]#
[root@git-server GitTest]# git commit -m "New feature 5.py"
[dev 51b959c] New feature 5.py
 1 file changed, 1 insertion(+)
 create mode 100644 5.py
[root@git-server GitTest]#
[root@git-server GitTest]# git checkout master
Switched to branch 'master'
[root@git-server GitTest]#
[root@git-server GitTest]# cat 5.py
cat: 5.py: No such file or directory

切换到master分支,没有找到5.py

2)合并分支,再查看,就能在master分支上查看到了。

bash 复制代码
[root@git-server GitTest]# git merge dev
Updating 8153d25..51b959c
Fast-forward
 5.py | 1 +
 1 file changed, 1 insertion(+)
 create mode 100644 5.py
[root@git-server GitTest]# cat 5.py
New feature

分支冲突:

有些复杂的情况会造成冲突,这个时候git就不能帮我们自动的合并分支。 我们就要手动处理冲突。

1)在dev上修改文件:

bash 复制代码
[root@git-server GitTest]# git checkout dev
Switched to branch 'dev'
[root@git-server GitTest]# echo "冲突测试" >> 5.py
[root@git-server GitTest]#
[root@git-server GitTest]# cat 5.py
New feature
冲突测试

2)提交分支上的修改:

bash 复制代码
[root@git-server GitTest]# git add 5.py
[root@git-server GitTest]# git commit -m "冲突测试"
[dev 844bd61] 冲突测试
 1 file changed, 1 insertion(+)

3)切换master分支,也修改相同的文件:

bash 复制代码
[root@git-server GitTest]# git checkout master
Switched to branch 'master'
[root@git-server GitTest]#
[root@git-server GitTest]# echo "哈哈" >> 5.py
[root@git-server GitTest]#
[root@git-server GitTest]# cat 5.py
New feature
哈哈

4)然后提交master分支上的修改:

bash 复制代码
[root@git-server GitTest]# git add 5.py
[root@git-server GitTest]# git commit -m "冲突测试"
[master 4721701] 冲突测试
 1 file changed, 1 insertion(+)

5)合并dev分支到master,就会出现冲突了。

bash 复制代码
[root@git-server GitTest]# git merge dev
Auto-merging 5.py
CONFLICT (content): Merge conflict in 5.py
Automatic merge failed; fix conflicts and then commit the result.

6)手工解决冲突:

git使用<<<<<<<<<,=========,>>>>>>>>符号分割冲突的内容,手动删除这些符号,并修改成你想要的内容。

bash 复制代码
[root@git-server GitTest]# cat 5.py
New feature
<<<<<<< HEAD
哈哈
=======
冲突测试
>>>>>>> dev
[root@git-server GitTest]# vim 5.py
[root@git-server GitTest]#
[root@git-server GitTest]# cat 5.py
New feature
冲突测试

7)解决冲突后添加并提交,最后再合并。

bash 复制代码
[root@git-server GitTest]# git add 5.py
[root@git-server GitTest]# git commit -m  "冲突解决"
[master b956e9d] 冲突解决
[root@git-server GitTest]#
[root@git-server GitTest]# git merge dev
Already up-to-date.

删除分支:

使用git branch -d 分支名来删除分支。==注意:== 不能删除当前使用的分支.

bash 复制代码
[root@git-server GitTest]# git branch
  dev
* master
[root@git-server GitTest]#
[root@git-server GitTest]# git branch -d dev
Deleted branch dev (was 844bd61).
[root@git-server GitTest]#
[root@git-server GitTest]# git branch
* master

感觉这样学下来,思路还是很清楚的。

之前自己看书操作,总感觉有点乱。这样整理了,思路也是很明确的。

相关推荐
洛小豆11 分钟前
Git打标签仓库看不到?她说:豆子,你又忘了加 --tags!
git·后端·github
好奇的菜鸟3 小时前
理解 Git 命令 `git reset --hard origin/pre`:版本回退的“利刃”与使用禁忌
大数据·git
春生野草3 小时前
git的使用
git
今天头发还在吗3 小时前
解决 Git 推送冲突:使用 Rebase 整合远程更改
大数据·git·elasticsearch
蓝色空白的博客5 小时前
Git代码下拉更新推送操作用法整理
git
风也温柔☆7 小时前
IDEA/WebStorm 切换分支(超简单)
git·intellij-idea·webstorm·切换分支·checkout
Jammingpro18 小时前
【Git版本控制】Git初识、安装、仓库初始化与仓库配置(含git init、git config与配置无法取消问题)
java·git·elasticsearch
shark1 天前
无需放弃变更、关闭占用程序!用暂存区和 git底层命令实现 Git 变更备份
git·shell·自动化运维
_poplar_1 天前
15 【C++11 新特性】统一的列表初始化和变量类型推导
开发语言·数据结构·c++·git·算法
北城笑笑1 天前
Git 10 ,使用 SSH 提升 Git 操作速度实践指南( Git 拉取推送响应慢 )
前端·git·ssh