一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Git概述及知識(shí)詳解

硬件攻城獅 ? 來(lái)源:技術(shù)讓夢(mèng)想更偉大 ? 作者:技術(shù)讓夢(mèng)想更偉大 ? 2022-11-08 14:16 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群


	
			
							
							
							

Git 概述

Git 是一個(gè)免費(fèi)的、開(kāi)源的分布式版本控制系統(tǒng),可以快速高效地處理從小型到大型的各種項(xiàng)目。 Git 的特色是分支,人家圖標(biāo)上都敢這么畫(huà)了。 對(duì)了,這里要提一下,Git 和 Linux 是同一個(gè)爸爸,所以 Linux 系統(tǒng)上能跑的原生指令 Git 上面也都可以,反之也一樣。

git 分區(qū)原理

工作區(qū)。新文件沒(méi)被add到暫存區(qū),顯紅色。 暫存區(qū)。進(jìn)倉(cāng)庫(kù)前暫時(shí)存放區(qū)域,未對(duì)本地倉(cāng)庫(kù)生效。對(duì)暫存區(qū)文件修改,顯藍(lán)色。第一次創(chuàng)建并add到暫存區(qū)的文件,由于遠(yuǎn)程倉(cāng)庫(kù)沒(méi)同步,顯綠色。(注:存放在 “.git/index目錄”。 本地倉(cāng)庫(kù)。暫存區(qū)commit代碼放入本地倉(cāng)庫(kù),通過(guò) push 推送到遠(yuǎn)程倉(cāng)庫(kù)。(注:存在“.git”目錄。 遠(yuǎn)程倉(cāng)庫(kù)。在前面的話,倉(cāng)庫(kù)里都有些什么東西只有你自己知道,但是一旦把本地倉(cāng)庫(kù)推到遠(yuǎn)程倉(cāng)庫(kù)之后,倉(cāng)庫(kù)里有什么東西大家就都知道了。

Git 常用指令

6ef33f82-5f1f-11ed-8abf-dac502259ad0.png

本篇講解包括但不限于這些命令。 6f038342-5f1f-11ed-8abf-dac502259ad0.png

設(shè)置用戶簽名

開(kāi)頭兩個(gè)命令是用來(lái)設(shè)置用戶簽名的,這個(gè)一般就用一次就完事兒了,因?yàn)槟阋峤淮a的時(shí)候是需要責(zé)任跟蹤的。 這個(gè) name,email 啥的,人家也不會(huì)去認(rèn)證,不過(guò)組里面肯定是會(huì)有規(guī)范的,也不會(huì)讓你想起啥名就隨便起吧。 6f038342-5f1f-11ed-8abf-dac502259ad0.png

初始化本地庫(kù)

新手一般就老老實(shí)實(shí) git init 起手嘛,昨天我也是這么問(wèn)我導(dǎo)師的,他說(shuō)不用,直接 git clone 就好了。我想想也是,團(tuán)隊(duì)開(kāi)發(fā)嘛。 6f038342-5f1f-11ed-8abf-dac502259ad0.png

查看本地庫(kù)狀態(tài)

git status
首次查看,工作區(qū)是沒(méi)有什么文件的:
$ git status
On branch master
No commits yet
nothing to commit (create/copy files and use "git add" to track)
當(dāng)我們新增了一個(gè)文件之后,再查看狀態(tài), 會(huì)檢測(cè)到未追蹤的文件:
$ git status
On branch master
No commits yet
Untracked files:
 (use "git add ..." to include in what will be committed)
 hello.txt
nothing added to commit but untracked files present (use "git add" 
to track)
6f038342-5f1f-11ed-8abf-dac502259ad0.png

添加暫存區(qū)

git add 文件名
$ git add hello.txt
warning: LF will be replaced by CRLF in hello.txt.
The file will have its original line endings in your working 
directory.
再次查看狀態(tài)(檢測(cè)到暫存區(qū)有新文件:
$ git status
On branch master
No commits yet
Changes to be committed:
 (use "git rm --cached ..." to unstage)
 new file: hello.txt
6f038342-5f1f-11ed-8abf-dac502259ad0.png

提交本地庫(kù)

git commit -m "日志信息" 文件名
$ git commit -m "my first commit" hello.txt
warning: LF will be replaced by CRLF in hello.txt.
The file will have its original line endings in your working 
directory.
[master (root-commit) 86366fa] my first commit
1 file changed, 16 insertions(+)
create mode 100644 hello.txt
再查看狀態(tài)(沒(méi)有文件需要提交):
$ git status
On branch master
nothing to commit, working tree clean
6f038342-5f1f-11ed-8abf-dac502259ad0.png

修改文件

修改一下文件之后再查看狀態(tài):
$ git status
On branch master
Changes not staged for commit:
 (use "git add ..." to update what will be committed)
 (use "git checkout -- ..." to discard changes in working 
directory)
 modified: hello.txt
no changes added to commit (use "git add" and/or "git commit -a")
那么接下來(lái)就需要再次將修改的文件提交到暫存區(qū),然后提交到本地倉(cāng)庫(kù)。 6f038342-5f1f-11ed-8abf-dac502259ad0.png

查看歷史版本

git reflog 查看版本信息
git log 查看版本詳細(xì)信息
如果是想快速瀏覽版本信息,可以使用 reflog 即可,畢竟公司項(xiàng)目版本迭代信息可能已經(jīng)很多了,想看詳細(xì)日志也得看你有沒(méi)有那個(gè)精力了。
$ git reflog
087a1a7 (HEAD -> master) HEAD@{0}: commit: my third commit
ca8ded6 HEAD@{1}: commit: my second commit
86366fa HEAD@{2}: commit (initial): my first commit
6f038342-5f1f-11ed-8abf-dac502259ad0.png

版本

以前我只知道版本回退,現(xiàn)在我知道原來(lái)還能向新。
git reset --hard 版本號(hào)
版本號(hào)是什么?版本號(hào),查看一下日志就能看到了。
$ git reflog
087a1a7 (HEAD -> master) HEAD@{0}: commit: my third commit
ca8ded6 HEAD@{1}: commit: my second commit
86366fa HEAD@{2}: commit (initial): my first commit
--切換到 86366fa 版本,也就是我們第一次提交的版本
$ git reset --hard 86366fa
HEAD is now at 86366fa my first commit
--切換完畢之后再查看歷史記錄,當(dāng)前成功切換到了 86366fa 版本
$ git reflog
86366fa (HEAD -> master) HEAD@{0}: reset: moving to 86366fa
087a1a7 HEAD@{1}: commit: my third commit
ca8ded6 HEAD@{2}: commit: my second commit
86366fa (HEAD -> master) HEAD@{3}: commit (initial): my first commit
--然后查看文件 hello.txt,發(fā)現(xiàn)文件內(nèi)容已經(jīng)變化
Git 切換版本,底層其實(shí)是移動(dòng)的 HEAD 指針。

Git 分支操作

在版本控制過(guò)程中,同時(shí)推進(jìn)多個(gè)任務(wù),為每個(gè)任務(wù),我們就可以創(chuàng)建每個(gè)任務(wù)的單獨(dú)分支。使用分支意味著程序員可以把自己的工作從開(kāi)發(fā)主線上分離開(kāi)來(lái),開(kāi)發(fā)自己分支的時(shí)候,不會(huì)影響主線分支的運(yùn)行。對(duì)于初學(xué)者而言,分支可以簡(jiǎn)單理解為副本,一個(gè)分支就是一個(gè)單獨(dú)的副本。(分支底層其實(shí)也是指針的引用。

分支基本操作

查看分支

小伙子,不要一上來(lái)就想著創(chuàng)建分支嘛。先看看前輩們已經(jīng)達(dá)到了哪個(gè)高度了嘛。
git branch -v
$ git branch -v
* master 087a1a7 my third commit (*代表當(dāng)前所在的分區(qū))

創(chuàng)建分支

git branch 分支名
$ git branch hot-fix
$ git branch -v
hot-fix 087a1a7 my third commit (剛創(chuàng)建的新的分支,并將主分支 master
的內(nèi)容復(fù)制了一份)
* master 087a1a7 my third commit

分支開(kāi)發(fā)

接下來(lái)就可以在分支上進(jìn)行開(kāi)發(fā)了,開(kāi)發(fā)完之后記得將代碼提交到本地倉(cāng)庫(kù)。

切換分支

git checkout 分支名
$ git checkout hot-fix
Switched to branch 'hot-fix'
--發(fā)現(xiàn)當(dāng)先分支已由 master 改為 hot-fix

合并分支

git merge 分支名
這里有個(gè)要注意的點(diǎn):不僅是可以把旁支合并到主支上,主支也可以被合并到分支上,分支之間也可以互相合并。 反正你愛(ài)怎么玩怎么玩,都是在你本地倉(cāng)庫(kù)上,又沒(méi)有推送到遠(yuǎn)程倉(cāng)庫(kù)。 那現(xiàn)在我們想把旁支合并到主支上要怎么做呢?
1、切換到主支
2、git merge 旁支名
這樣就萬(wàn)事大吉了嗎?不一定的。腦子清醒的話很容易想到一個(gè)問(wèn)題:主支修改了一個(gè)文件,分支也修改了同一個(gè)文件,現(xiàn)在以誰(shuí)的為準(zhǔn)? 腦子更清醒的人就要說(shuō)了:你傻呀,我 clone 下來(lái)就切到分支去操作了,在我本地倉(cāng)庫(kù)我又不會(huì)去動(dòng)主支的。 腦子再清醒一點(diǎn)的人已經(jīng)懶的跟他說(shuō)了:大哥,咱這是團(tuán)隊(duì)開(kāi)發(fā),咱的本地倉(cāng)庫(kù)早晚是都要合并到主線上的。

合并沖突解決

沖突產(chǎn)生的表現(xiàn):后面狀態(tài)為 MERGING 打開(kāi)沖突文件可以看到?jīng)_突的地方:
hello git! hello atguigu!
<<<<<<< HEAD
hello git! hello atguigu! master test
hello git! hello atguigu!
=======
hello git! hello atguigu!
hello git! hello atguigu! hot-fix test
>>>>>>> hot-fix
HEAD 到 === 的部分是主支的,后面是 hot-fix 的 沖突產(chǎn)生的原因: 合并分支時(shí),兩個(gè)分支在同一個(gè)文件的同一個(gè)位置有兩套完全不同的修改。Git 無(wú)法替我們決定使用哪一個(gè)。必須人為決定新代碼內(nèi)容。 解決辦法:
1、刪掉沖突中不要的部分,留下最終的部分
2、git add 添加到暫存區(qū)
3、 git commit -m 注意,此時(shí)的 commit 后面不能帶文件名。帶文件名是幾個(gè)意思呢?到底用哪個(gè)呢?
然后就會(huì)發(fā)現(xiàn)合并成功了。

Git 團(tuán)隊(duì)協(xié)作機(jī)制

團(tuán)隊(duì)協(xié)作

跨團(tuán)隊(duì)協(xié)作

6f68d29c-5f1f-11ed-8abf-dac502259ad0.png

遠(yuǎn)程倉(cāng)庫(kù)

這里不說(shuō) github,因?yàn)檫€有 gitlab,公司內(nèi)部代碼怎么能放到廣域網(wǎng)上呢!?。?/span>

6f77232e-5f1f-11ed-8abf-dac502259ad0.png

6f038342-5f1f-11ed-8abf-dac502259ad0.png

別名

為什么要?jiǎng)e名呢?其實(shí)起不起別名都無(wú)所謂,主要是有個(gè)別名方便操作。你說(shuō)是記一個(gè)網(wǎng)址容易還是記一個(gè)自己起的名字容易嘞?
$ git remote -v
$ git remote add ori https://github.com/xxx.git
$ git remote -v
ori https://github.com/xxx.git (fetch)
ori https://github.com/xxx.git (push)
6f038342-5f1f-11ed-8abf-dac502259ad0.png

推送本地倉(cāng)庫(kù)到遠(yuǎn)程倉(cāng)庫(kù)

當(dāng)文件還在本地倉(cāng)庫(kù)的時(shí)候,咱怎么玩都行。但是一旦推送上去了,那就產(chǎn)生歷史版本了,大家都看得到了。 不過(guò)這個(gè)推送啊,也不是咱想推送就能推送的,還得管理員給咱授權(quán),這個(gè)不難理解吧。
git push 別名 分支
$ git push ori master
Logon failed, use ctrl+c to cancel basic credential prompt.
Username for 'https://github.com': atguiguyueyue
Counting objects: 3, done.
Delta compression using up to 12 threads.
Compressing objects: 100% (2/2), done.
Writing objects: 100% (3/3), 276 bytes | 276.00 KiB/s, done.
Total 3 (delta 0), reused 0 (delta 0)
To https://github.com/atguiguyueyue/git-shTest.git
* [new branch] master -> master
6f038342-5f1f-11ed-8abf-dac502259ad0.png

克隆遠(yuǎn)程倉(cāng)庫(kù)到本地

這不用說(shuō)吧,這個(gè)很簡(jiǎn)單。咱雖然說(shuō)之前不會(huì)推送,但是拉取還是沒(méi)有問(wèn)題的。 clone 會(huì)做如下操作: 1、拉取代碼。2、初始化本地倉(cāng)庫(kù)。3、創(chuàng)建別名。 會(huì)創(chuàng)建別名,你 clone 之后用 git remote -v 看一下,一般是 origin。 6f038342-5f1f-11ed-8abf-dac502259ad0.png

拉取遠(yuǎn)程庫(kù)內(nèi)容

這個(gè)有兩個(gè)辦法,昨天我用的是先 clone,在 checkout 的方式選擇我要的分支。 也可以直接 pull:
git pull 遠(yuǎn)程庫(kù)地址別名 遠(yuǎn)程分支名
$ git pull ori master
remote: Enumerating objects: 5, done.
remote: Counting objects: 100% (5/5), done.
remote: Compressing objects: 100% (1/1), done.
remote: Total 3 (delta 1), reused 3 (delta 1), pack-reused 0
Unpacking objects: 100% (3/3), done.
From https://github.com/atguiguyueyue/git-shTest
* branch master -> FETCH_HEAD
 7cb4d02..5dabe6b master -> ori/master
Updating 7cb4d02..5dabe6b
Fast-forward
hello.txt | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)

審核編輯 :李倩

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11511

    瀏覽量

    213837
  • Git
    Git
    +關(guān)注

    關(guān)注

    0

    文章

    205

    瀏覽量

    16221

原文標(biāo)題:Git詳解,一看就懂!

文章出處:【微信號(hào):mcu168,微信公眾號(hào):硬件攻城獅】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    主流版本控制工具Git vs Perforce P4:架構(gòu)模式、性能、大文件管理及分支管理對(duì)比詳解

    Git vs Perforce P4,如何選型?架構(gòu)模式、性能、大文件管理、分支策略四大維度對(duì)比,幫你全面了解兩者的核心差異,選擇更合適你團(tuán)隊(duì)需求的版本控制系統(tǒng)。
    的頭像 發(fā)表于 06-13 14:52 ?205次閱讀
    主流版本控制工具<b class='flag-5'>Git</b> vs Perforce P4:架構(gòu)模式、性能、大文件管理及分支管理對(duì)比<b class='flag-5'>詳解</b>

    SSH常用命令詳解

    SSH常用命令詳解
    的頭像 發(fā)表于 06-04 11:30 ?655次閱讀

    Thread標(biāo)準(zhǔn)認(rèn)證概述

    本篇知識(shí)庫(kù)文章概述了開(kāi)發(fā)人員如何將其Thread物聯(lián)網(wǎng)設(shè)備進(jìn)行Thread Group認(rèn)證所需的步驟,并重點(diǎn)介紹使用Silicon Labs(芯科科技)的EFR32無(wú)線射頻器件的相關(guān)流程。
    的頭像 發(fā)表于 06-04 10:10 ?301次閱讀
    Thread標(biāo)準(zhǔn)認(rèn)證<b class='flag-5'>概述</b>

    嵌入式學(xué)習(xí)-飛凌嵌入式ElfBoard ELF 1板卡-移植前準(zhǔn)備之git管理內(nèi)核源碼

    我們前邊已經(jīng)介紹過(guò)Git工具,是一個(gè)非常實(shí)用的代碼管理工具。如果驗(yàn)證編譯出的內(nèi)核能夠正常啟動(dòng),就可以將源碼用git工具管理起來(lái)。可以清楚的了解源碼改動(dòng)記錄。如果不小心把源碼改亂了還可以進(jìn)行版本
    發(fā)表于 01-23 10:51

    飛凌嵌入式ElfBoard ELF 1板卡-移植前準(zhǔn)備之git管理內(nèi)核源碼

    我們前邊已經(jīng)介紹過(guò)Git工具,是一個(gè)非常實(shí)用的代碼管理工具。如果驗(yàn)證編譯出的內(nèi)核能夠正常啟動(dòng),就可以將源碼用git工具管理起來(lái)??梢郧宄牧私庠创a改動(dòng)記錄。如果不小心把源碼改亂了還可以進(jìn)行版本
    發(fā)表于 01-22 10:39

    飛凌嵌入式ElfBoard ELF 1板卡-git管理源碼之git安裝和使用

    git是什么?git是一個(gè)開(kāi)源的分布式版本控制系統(tǒng),可以有效、高速地處理從很小到非常大的項(xiàng)目版本管理,也是Linus Torvalds為了幫助管理Linux內(nèi)核開(kāi)發(fā)而開(kāi)發(fā)的一個(gè)開(kāi)放源碼的版本控制軟件
    發(fā)表于 01-14 09:08

    云服務(wù)器 Flexus X 實(shí)例:部署 Gitea,擁有自己的 Git 倉(cāng)庫(kù),管理本地代碼

    本篇文章通過(guò)部署 Gitea,實(shí)現(xiàn)本地 Git 倉(cāng)庫(kù),真實(shí)體驗(yàn)了“云服務(wù)器 Flexus X 實(shí)例”,深感其卓越性能與靈活性。這款實(shí)例以其六倍于常的強(qiáng)勁算力,搭配旗艦級(jí)的操作體驗(yàn),廣泛適用于高科技
    的頭像 發(fā)表于 01-07 16:59 ?416次閱讀
    云服務(wù)器 Flexus X 實(shí)例:部署 Gitea,擁有自己的 <b class='flag-5'>Git</b> 倉(cāng)庫(kù),管理本地代碼

    Flexus X 實(shí)例 C#/.Net Core 結(jié)合(git 代碼管理、docker 自定義鏡像)快速發(fā)布部署 - 讓你的項(xiàng)目飛起來(lái)~

    前言 ???云端部署新體驗(yàn),C# Web API 遇上 Git Docker,828 B2B 企業(yè)節(jié)特惠來(lái)襲!Flexus X 實(shí)例,為您的 C#應(yīng)用提供強(qiáng)大支撐,結(jié)合 Git 版本控制
    的頭像 發(fā)表于 12-25 21:15 ?594次閱讀
    Flexus X 實(shí)例 C#/.Net Core 結(jié)合(<b class='flag-5'>git</b> 代碼管理、docker 自定義鏡像)快速發(fā)布部署 - 讓你的項(xiàng)目飛起來(lái)~

    詳解MySQL多實(shí)例部署

    詳解MySQL多實(shí)例部署
    的頭像 發(fā)表于 11-11 11:10 ?642次閱讀

    集成電路封裝基板工藝詳解(68頁(yè)P(yáng)PT)

    共讀好書(shū)歡迎掃碼添加小編微信掃碼加入知識(shí)星球,領(lǐng)取公眾號(hào)資料 原文標(biāo)題:集成電路封裝基板工藝詳解(68
    的頭像 發(fā)表于 11-01 11:08 ?739次閱讀

    集成電路封裝基板工藝詳解(68頁(yè)P(yáng)PT)

    共讀好書(shū)歡迎掃碼添加小編微信掃碼加入知識(shí)星球,領(lǐng)取公眾號(hào)資料 原文標(biāo)題:集成電路封裝基板工藝詳解(68
    的頭像 發(fā)表于 11-01 11:08 ?497次閱讀

    半導(dǎo)體封裝技術(shù)基礎(chǔ)詳解(131頁(yè)P(yáng)PT)

    共讀好書(shū)歡迎掃碼添加小編微信掃碼加入知識(shí)星球,領(lǐng)取公眾號(hào)資料 原文標(biāo)題:半導(dǎo)體封裝技術(shù)基礎(chǔ)詳解(131
    的頭像 發(fā)表于 11-01 11:08 ?1139次閱讀

    溫度振動(dòng)變送器的概述及功能介紹

    制造業(yè)還是戰(zhàn)略性新型產(chǎn)業(yè)都離不開(kāi)溫度振動(dòng)變送器的支持。 一、溫度振動(dòng)變送器的概述 溫度振動(dòng)變送器集成了溫度傳感技術(shù)和振動(dòng)傳感技術(shù),可以測(cè)量工業(yè)設(shè)備的振動(dòng)速度、表面溫度等參數(shù)。溫度振動(dòng)變送器具有MEMS 芯片,采用嵌入式技
    的頭像 發(fā)表于 08-20 17:18 ?860次閱讀

    安森美OBC系統(tǒng)解決方案設(shè)計(jì)指南

    “OBC系統(tǒng)解決方案設(shè)計(jì)指南”又上新了,第一篇文章介紹了系統(tǒng)用途、系統(tǒng)實(shí)施方法、系統(tǒng)說(shuō)明、市場(chǎng)趨勢(shì)和標(biāo)準(zhǔn)等,本文將繼續(xù)介紹解決方案概述及拓?fù)洹?/div>
    的頭像 發(fā)表于 08-20 16:34 ?1710次閱讀
    安森美OBC系統(tǒng)解決方案設(shè)計(jì)指南

    行程開(kāi)關(guān)概述及應(yīng)用介紹

    一、行程開(kāi)關(guān)概述 行程開(kāi)關(guān),作為位置開(kāi)關(guān)(限位開(kāi)關(guān))的一種,是廣泛應(yīng)用于小電流環(huán)境中的主要控制電器。它通過(guò)機(jī)械運(yùn)動(dòng)部件的觸發(fā)來(lái)實(shí)現(xiàn)觸點(diǎn)的接通或斷開(kāi),進(jìn)而控制電路,以實(shí)現(xiàn)特定的控制目標(biāo)。這種開(kāi)關(guān)機(jī)
    的頭像 發(fā)表于 08-16 17:31 ?2314次閱讀