Git图文使用教程详解(二)
🥳Git图文使用教程详解(二)
✍、Git图文使用教程说明
- Git 版本: 2.31.0.windows.1
- IDEA版本:2021.1
- 主要记录 git 的常用命令、IDEA 集成 git、git与GitHub、IDEA 集成 GitHub、Gitee等(详细图文步骤记录)
- 配套视频参考:【尚硅谷】5h打通Git全套教程
❤️Git图文使用教程详解 | 地址 |
---|---|
❤️Git图文使用教程详解(一) | # |
❤️Git图文使用教程详解(二) | # |
❤️Git图文使用教程详解(三) | # |
💻一、Git分支
🎯1.1、什么是分支
- 在版本控制过程中, 同时推进多个任务, 为每个任务, 我们就可以创建每个任务的单独分支。
- 使用分支意味着程序员可以为自己的工作从开发主线上分离开来, 开发字迹分支的时候 , 不会影响主线分支的运行。
- 对于初学者而言,分支可以理解为副本,一个分支就是一个简单的副本。
🪀1.2、分支的好处
- 同时并行推进多个分支的开发,提高开发效率。
- 各个分支在开发的过程中,如果一个分支开发失败,不会对其他分支造成任何影响。失败的分支删除重新开始就可以了。
🎾1.3、分支的操作
命令名称 | 作用 |
---|---|
git branch 分支名 | 创建分支 |
git branch -v | 查看分支 |
git checkout 分支名 | 切换分支 |
git merge 分支名 | 把指定的分支合并到当前分支上 |
📌1.3.1、查看分支
基本语法:git branch -v
data:image/s3,"s3://crabby-images/bad92/bad9219a568c7f8d12a54dd2d1d2da19dc4d1f59" alt="image-20220514144922120"
📍1.3.2、创建分支
基本语法:git branch 分支名
data:image/s3,"s3://crabby-images/73241/73241a08d073b22552af332dd3cf7f1d86b41eaa" alt="image-20220514145223931"
✂️1.3.3、切换分支
基本语法:git checkout 分支名
data:image/s3,"s3://crabby-images/9e9cb/9e9cbfada2fcdd4d2cf3dde82e04b7cb983f4451" alt="image-20220514145423064"
🧲1.3.4、修改分支
data:image/s3,"s3://crabby-images/a3941/a3941e7379972510d53b5d7d93a9f5013d9a6d74" alt="image-20220514150032675"
📍1.3.5、合并分支
基本语法:git merge 分支名
①正常合并不冲突
②合并产生冲突
冲突产生的原因:
- 合并分支时,两个分支在同一个文件的同一个位置有两套完全不同的修改。
- 有两套完全不同的修改。 Git无法替我们决定使用哪一个。必须 人为决定新代码内容。
例如,我们首先在 master 分支的倒数第二行进行修改,并将其添加到暂存区,再提交到本地库
data:image/s3,"s3://crabby-images/d3200/d320087a68ad3779412b7724ec01c89ad20efda3" alt="image-20220514151306699"
接着,我们去 hot-fix 分支的倒数第一行进行修改,并将其添加到暂存区,再提交到本地库
data:image/s3,"s3://crabby-images/2ba25/2ba25788d5e118e14888c248528d3013bc295d90" alt="image-20220514151727947"
之后我们在 master 分支上合并 hot-fix 分支,发现产生冲突
data:image/s3,"s3://crabby-images/46215/462150e331d94496fe75b3ead0977557d8a886bb" alt="image-20220514152028233"
解决冲突
-
编辑有冲突的文件,删除特殊符号,决定要使用的内容
特殊符号:
<<<<<< HEAD
当前分支的代码=======
合并过来的代码>>>>>>>hot-fix
data:image/s3,"s3://crabby-images/51eb6/51eb6014bd4dae639bf354d5c71fe0179eb01bc3" alt="image-20220514152302492"
data:image/s3,"s3://crabby-images/7d504/7d5043923a315c4a0352ef20cbec2f4ab378097d" alt="image-20220514152453845"
删除完成之后保存,再次添加到暂存区,并再次提交到本地库(注意:此时使用 git commit 命令时候不能带文件名)
data:image/s3,"s3://crabby-images/bf2cc/bf2cc5b78a10a8e2f33a81eff38389647d0bfe04" alt="image-20220514152857072"
🔍二、Git团队协作机
🏓2.1、团队内协作
data:image/s3,"s3://crabby-images/a2cbb/a2cbb1d6284fa36310188cdcb7bf6e48daf618e7" alt="image-20220514153043747"
举个例子:
岳不群首先用 git 初始化自己的本地库,写了一套华山剑法,
利用push 命令将自己的本地库推送到代码托管中心(Github、Gitee),
大弟子令狐冲通过 clone 克隆命令完整的复制到自己的本地库,
令狐冲修改两招之后将自己的本地库再次 push 到代码托管中心,
这样岳不群就可以通过 pull 命令拉取令狐冲修改的代码 来更新自己的本地库。
💗2.2、跨团队协作
data:image/s3,"s3://crabby-images/a8c9d/a8c9dd50b3d06c3e3fd7f99e1eadd30da838eed7" alt="image-20220514153219290"
令狐冲请东方不败改代码,东方不败通过 fork 命令从岳不群的的远程库中拿取代码,
再通过 clone 克隆命令到自己的本地库,修改完成后使用 push 推送到在自己的远程库,
使用 Pull request 拉取请求给岳不群,岳不群审核完成后使用 merge 命令合并对方的代码到自己的远程
中,再通过 pull 命令到自己的本地库中,这样修改过后的华山剑法岳不群和令狐冲就都可以使用了。
☔三、Github
🌼3.1、创建远程仓库
🗡️3.1.1、Github远程仓库
data:image/s3,"s3://crabby-images/35df5/35df5a6050d025d264090d4abc0139abf335cc43" alt="image-20220514153925971"
🪒3.1.2、Gitee远程仓库
🌈3.2、远程仓库操作
命令名称 | 作用 |
---|---|
git remote -v | 查看当前所有远程地址别名 |
git remote add 别名 远程地址 | 起别名 |
git push 别名 分支 | 推送本地分支上的内容克隆到本地 |
git clone 远程地址 | 将远程仓库的内容克隆到本地 |
git pull 远程库地址别名 远程分支名 | 将远程仓库对于分支最新内容拉下来后与当前本地分支直接合并 |
💐3.2.1、创建远程仓库别名
①、Gihub
基本语法:
git remote -v
查看当前所有远程地址别名git remote add 别名 远程地址
起别名
注意:起的别名最好和本地库的名称一致
②、Gitee
data:image/s3,"s3://crabby-images/fe25e/fe25edff4577f1ccfcc43072e791648251ec8521" alt="image-20220514155737527"
🧲3.2.2、推送本地分支到远程仓库
基本语法:git push 别名 分支
data:image/s3,"s3://crabby-images/f44d5/f44d566bca0109d9dbb9028621e4cf4677be59f6" alt="image-20220514155946799"
我们在 gitee 上查看我们的 git-demo 仓库,发现有我们推送的hello.txt 文件
data:image/s3,"s3://crabby-images/036fe/036fe2fb8aead90c7c16bf504be1349416138c4f" alt="image-20220514160033845"
🧨3.2.3、拉取远程库分支到本地库
语法:git pull 别名 分支
我们在远程库进行 hello.txt 的文件修改
data:image/s3,"s3://crabby-images/7da41/7da4132ea3569cd38dd61fa414feedc7a247ab69" alt="image-20220514160320320"
然后在本地库将远程库的代码 拉取
data:image/s3,"s3://crabby-images/b1cef/b1cef22b6278a631650a1df484f3479fce23115c" alt="image-20220514160515989"
data:image/s3,"s3://crabby-images/67837/67837145af38f9d971adf50449430912bcb15457" alt="image-20220515121129097"
🔖3.2.3、克隆远程仓库到本地
基本语法:git clone 远程地址
我们另一台用户需要克隆我们的远程仓库到他的本地库,由于是使用一台电脑模拟,所以在克隆之前需要在
凭据管理器下删除我们之前的 gitee 凭据
data:image/s3,"s3://crabby-images/30646/3064681ff9b5145a7807317b7cef3f8f42b97c47" alt="image-20220514160834274"
我们新建一个文件夹 git-clone,然后在此文件夹下右键 git bash here,之后进行克隆
data:image/s3,"s3://crabby-images/173d2/173d2baae9607835a2e6a215c1185c96a2da10a1" alt="image-20220514161030108"
data:image/s3,"s3://crabby-images/6e0e2/6e0e24d8374dafde7dff9aef001ad3a592ef127e" alt="image-20220514161235444"
🤔3.3、邀请加入团队
😃3.3.1、Gitee
我们在 git-clone(假设这是大弟子令狐冲) 文件夹里面进行代码修改,修改完后添加到暂存区,再提交到本地库,之后 push 到我们的远程库
data:image/s3,"s3://crabby-images/4bac2/4bac24e8f627b20a67dc803a99cc39acfaaab1b5" alt="image-20220514161516353"
data:image/s3,"s3://crabby-images/ec4fc/ec4fc03a890dda6ac029121ec2bf5d8cfc589f4a" alt="image-20220514161455140"
data:image/s3,"s3://crabby-images/6bde4/6bde47f47251d6632c13f86d196c168792001a93" alt="image-20220514161538950"
令狐成成为仓库开发者被拉入团队后,我们再次在令狐冲文件夹使用进行 push
data:image/s3,"s3://crabby-images/0ce8c/0ce8c938c762ee40a62f240bbc1a03b47ce4b138" alt="image-20220514161603748"
push 到远程库成功,我们在远程库查看
data:image/s3,"s3://crabby-images/cd668/cd668c263a082e881bb86cf4145b01baa9bb4757" alt="image-20220514161623403"
🥮3.3.2、Github
data:image/s3,"s3://crabby-images/c01a0/c01a0b15a801ea19ffee35af3b4d67a2a9ecbeb1" alt="image-20220514161724421"
data:image/s3,"s3://crabby-images/e1204/e120422577a80d0a381827bc1a50e1daf2c9f709" alt="image-20220514161738370"
复制地址并发给该用户
data:image/s3,"s3://crabby-images/790fc/790fc02f87bd86a05b7c60fd58f6937960b5b763" alt="image-20220514161806293"
在 atguigulinghuchong这个账号 中的 地址 栏 复制 收到邀请 的 链接 ,点击接受邀请。
data:image/s3,"s3://crabby-images/02879/0287953ac86bfc1c48af36035812e86a22326593" alt="image-20220514161827779"
🧹3.4、跨团队协作
🛶3.4.1、Gitee
将远程仓库的地址复制发给邀请跨团队协作的人,比如东方不败。
data:image/s3,"s3://crabby-images/6fe5c/6fe5cbc95b82fe112aa222256813448e7c85d57a" alt="image-20220514162035450"
在东方不败的 Gitee账号里的地址栏复制收到的链接,然后点击 Fork将项目叉到自己的本地仓库
data:image/s3,"s3://crabby-images/aa31d/aa31d7815a7e82e95a6f8466496e15e1ae0d1eea" alt="image-20220514162129821"
data:image/s3,"s3://crabby-images/feafa/feafa70c79752dce34737406e28812bb6e93f342" alt="image-20220515121357503"
接下来点击上方的 Pull Requests 请求,并创建一个新的请求
合并之后我们在岳不群的 git-demo 下就可以看到东方不败的代码
data:image/s3,"s3://crabby-images/7f771/7f771afd4e24ae3458fd3fbcfdd0387620795888" alt="image-20220514162836444"