之前Git操作——簡(jiǎn)單使用
遠(yuǎn)程創(chuàng)建一個(gè)git項(xiàng)目耍群,clone到本地,即為本地倉(cāng)庫(kù)(即一個(gè)含有.git隱藏文件夾的項(xiàng)目文件夾)找筝,經(jīng)過本地終端命令的操作蹈垢,再push到遠(yuǎn)程庫(kù)。所有的修改袖裕、刪除曹抬、提交、推送等都是由這個(gè).git的文件進(jìn)行記錄的急鳄,如果去掉谤民,這個(gè)項(xiàng)目就是一個(gè)普通的文件夾堰酿。
現(xiàn)在Git操作——復(fù)雜使用
本地新建一個(gè)git項(xiàng)目,push到遠(yuǎn)程空倉(cāng)庫(kù)张足。
再在終端上操作
(1)在本地任意創(chuàng)建一個(gè)文件夾(此時(shí)触创,這個(gè)還是空文件夾,不是倉(cāng)庫(kù))
?mkdir? blogtest_01
(2)看github項(xiàng)目主頁(yè)上的提示
?touch README.md
執(zhí)行status查看:
?git? status
出現(xiàn)報(bào)錯(cuò):fatal: Not a git repository (or any of the parent directories): .git?为牍,即沒有倉(cāng)庫(kù)
(3)空文件夾初始化一個(gè)倉(cāng)庫(kù)
git init
出現(xiàn)提示:Initialized empty Git repository in C:/Users/zq/Desktop/gitxuexi/blogtest_01/.git/ 哼绑,即說明已經(jīng)初始化一個(gè)空的倉(cāng)庫(kù)
#驗(yàn)證倉(cāng)庫(kù)查看:
ls? -a
即會(huì)出現(xiàn).git相關(guān)的文件夾,代表倉(cāng)庫(kù)已在本地建成
執(zhí)行status再查看:
git? status
(4)開始添加碉咆、暫存抖韩、提交一系列本地操作
git add .
git commit -am "init"
本地新建倉(cāng)庫(kù)進(jìn)行推送(注意這是一個(gè)重要點(diǎn)):
git? push
注意:會(huì)出現(xiàn)異常,因?yàn)楸镜匦陆ǖ?i>blogtest_01起初并不知道是指向遠(yuǎn)程庫(kù)blogtest_01疫铜,所以需要執(zhí)行一個(gè)指向地址的命令(在github項(xiàng)目主頁(yè)上有提示)帽蝶,即:
刷新一下GitHub
其他命令(這里以gitlab作為可改標(biāo)簽)
(1)慎用,強(qiáng)制推送會(huì)覆蓋別人的代碼
?git push -f origin master
(2)再添加一個(gè)遠(yuǎn)程庫(kù)的標(biāo)簽
?git remote add gitlab git@gitlab.com:abc/blog.git$ git remote -v
注:這里善用搜索引擎块攒,查找不會(huì)的命令意義:
?git remote -v?励稳,-v (即 –verbose 簡(jiǎn)寫,取首字母),顯示對(duì)應(yīng)的克隆地址囱井,列出詳細(xì)信息驹尼,在每一個(gè)名字后面列出其遠(yuǎn)程庫(kù)的url。
推送到gitlab標(biāo)簽:
git push gitlab master
(3)刪除gitlab標(biāo)簽
git remote remove gitlab
(4)修改origin標(biāo)簽對(duì)應(yīng)的地址(可以一個(gè)命令修改git的https或者ssh地址)
git remote set-url origin git@github.com:jirengu/blog3.git
(5)把gitlab 標(biāo)簽改名為coding
git remote rename gitlab coding
查看所有分支
git branch -a
(綠色分支——本地分支)*master?:當(dāng)前本地倉(cāng)庫(kù)主干master
(紅色分支——遠(yuǎn)程分支)remotes/origin/master?: 遠(yuǎn)程庫(kù)的主干
2庞呕、創(chuàng)建本地庫(kù)dev分支
git branch dev
git branch -a?
3新翎、切換主干和分支操作
(1)切換到dev分支
git checkout dev
(2)#切換到master主干
git checkout master
注:index.html沒有在master的主干上
結(jié)論:同一個(gè)項(xiàng)目文件夾,只要切換不同分支住练,就會(huì)展示不同分支的文件狀態(tài)
4地啰、推送到origin地址的dev分支上
git push origin dev
6、將dev分支內(nèi)容合并到主干上
git checkout master
git merge dev
可以查看一下
ls
然后讲逛,合并(merge)后的項(xiàng)目便是共同協(xié)作的結(jié)果
7亏吝、推送到遠(yuǎn)程庫(kù)中
git push origin master
沖突
假設(shè)A和B 同時(shí)修改同一個(gè)文件,同一個(gè)地方盏混,在執(zhí)行g(shù)it pull 本地更新本地合并時(shí)會(huì)發(fā)生沖突蔚鸥。
A執(zhí)行范例
B操作