在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

Git概述及知識詳解

硬件攻城獅 ? 來源:技術讓夢想更偉大 ? 作者:技術讓夢想更偉大 ? 2022-11-08 14:16 ? 次閱讀

	
			
							
							
							

Git 概述

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

git 分區原理

工作區。新文件沒被add到暫存區,顯紅色。 暫存區。進倉庫前暫時存放區域,未對本地倉庫生效。對暫存區文件修改,顯藍色。第一次創建并add到暫存區的文件,由于遠程倉庫沒同步,顯綠色。(注:存放在 “.git/index目錄” 本地倉庫。暫存區commit代碼放入本地倉庫,通過 push 推送到遠程倉庫。(注:存在“.git”目錄。 遠程倉庫。在前面的話,倉庫里都有些什么東西只有你自己知道,但是一旦把本地倉庫推到遠程倉庫之后,倉庫里有什么東西大家就都知道了。

Git 常用指令

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

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

設置用戶簽名

開頭兩個命令是用來設置用戶簽名的,這個一般就用一次就完事兒了,因為你要提交代碼的時候是需要責任跟蹤的。 這個 name,email 啥的,人家也不會去認證,不過組里面肯定是會有規范的,也不會讓你想起啥名就隨便起吧。 6f038342-5f1f-11ed-8abf-dac502259ad0.png

初始化本地庫

新手一般就老老實實 git init 起手嘛,昨天我也是這么問我導師的,他說不用,直接 git clone 就好了。我想想也是,團隊開發嘛。 6f038342-5f1f-11ed-8abf-dac502259ad0.png

查看本地庫狀態

git status
首次查看,工作區是沒有什么文件的:
$ git status
On branch master
No commits yet
nothing to commit (create/copy files and use "git add" to track)
當我們新增了一個文件之后,再查看狀態, 會檢測到未追蹤的文件:
$ 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

添加暫存區

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.
再次查看狀態(檢測到暫存區有新文件:
$ 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

提交本地庫

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
再查看狀態(沒有文件需要提交):
$ git status
On branch master
nothing to commit, working tree clean
6f038342-5f1f-11ed-8abf-dac502259ad0.png

修改文件

修改一下文件之后再查看狀態:
$ 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")
那么接下來就需要再次將修改的文件提交到暫存區,然后提交到本地倉庫。 6f038342-5f1f-11ed-8abf-dac502259ad0.png

查看歷史版本

git reflog 查看版本信息
git log 查看版本詳細信息
如果是想快速瀏覽版本信息,可以使用 reflog 即可,畢竟公司項目版本迭代信息可能已經很多了,想看詳細日志也得看你有沒有那個精力了。
$ 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

版本

以前我只知道版本回退,現在我知道原來還能向新。
git reset --hard 版本號
版本號是什么?版本號,查看一下日志就能看到了。
$ 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
--切換完畢之后再查看歷史記錄,當前成功切換到了 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,發現文件內容已經變化
Git 切換版本,底層其實是移動的 HEAD 指針。

Git 分支操作

在版本控制過程中,同時推進多個任務,為每個任務,我們就可以創建每個任務的單獨分支。使用分支意味著程序員可以把自己的工作從開發主線上分離開來,開發自己分支的時候,不會影響主線分支的運行。對于初學者而言,分支可以簡單理解為副本,一個分支就是一個單獨的副本。(分支底層其實也是指針的引用。

分支基本操作

查看分支

小伙子,不要一上來就想著創建分支嘛。先看看前輩們已經達到了哪個高度了嘛。
git branch -v
$ git branch -v
* master 087a1a7 my third commit (*代表當前所在的分區)

創建分支

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

分支開發

接下來就可以在分支上進行開發了,開發完之后記得將代碼提交到本地倉庫。

切換分支

git checkout 分支名
$ git checkout hot-fix
Switched to branch 'hot-fix'
--發現當先分支已由 master 改為 hot-fix

合并分支

git merge 分支名
這里有個要注意的點:不僅是可以把旁支合并到主支上,主支也可以被合并到分支上,分支之間也可以互相合并。 反正你愛怎么玩怎么玩,都是在你本地倉庫上,又沒有推送到遠程倉庫。 那現在我們想把旁支合并到主支上要怎么做呢?
1、切換到主支
2、git merge 旁支名
這樣就萬事大吉了嗎?不一定的。腦子清醒的話很容易想到一個問題:主支修改了一個文件,分支也修改了同一個文件,現在以誰的為準? 腦子更清醒的人就要說了:你傻呀,我 clone 下來就切到分支去操作了,在我本地倉庫我又不會去動主支的。 腦子再清醒一點的人已經懶的跟他說了:大哥,咱這是團隊開發,咱的本地倉庫早晚是都要合并到主線上的。

合并沖突解決

沖突產生的表現:后面狀態為 MERGING 打開沖突文件可以看到沖突的地方:
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 的 沖突產生的原因: 合并分支時,兩個分支在同一個文件的同一個位置有兩套完全不同的修改。Git 無法替我們決定使用哪一個。必須人為決定新代碼內容。 解決辦法:
1、刪掉沖突中不要的部分,留下最終的部分
2、git add 添加到暫存區
3、 git commit -m 注意,此時的 commit 后面不能帶文件名。帶文件名是幾個意思呢?到底用哪個呢?
然后就會發現合并成功了。

Git 團隊協作機制

團隊協作

跨團隊協作

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

遠程倉庫

這里不說 github,因為還有 gitlab,公司內部代碼怎么能放到廣域網上呢!!!

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

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

別名

為什么要別名呢?其實起不起別名都無所謂,主要是有個別名方便操作。你說是記一個網址容易還是記一個自己起的名字容易嘞?
$ 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

推送本地倉庫到遠程倉庫

當文件還在本地倉庫的時候,咱怎么玩都行。但是一旦推送上去了,那就產生歷史版本了,大家都看得到了。 不過這個推送啊,也不是咱想推送就能推送的,還得管理員給咱授權,這個不難理解吧。
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

克隆遠程倉庫到本地

這不用說吧,這個很簡單。咱雖然說之前不會推送,但是拉取還是沒有問題的。 clone 會做如下操作: 1、拉取代碼。2、初始化本地倉庫。3、創建別名。 會創建別名,你 clone 之后用 git remote -v 看一下,一般是 origin。 6f038342-5f1f-11ed-8abf-dac502259ad0.png

拉取遠程庫內容

這個有兩個辦法,昨天我用的是先 clone,在 checkout 的方式選擇我要的分支。 也可以直接 pull:
git pull 遠程庫地址別名 遠程分支名
$ 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(-)

審核編輯 :李倩

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • Linux
    +關注

    關注

    87

    文章

    11326

    瀏覽量

    209959
  • Git
    Git
    +關注

    關注

    0

    文章

    201

    瀏覽量

    15792

原文標題:Git詳解,一看就懂!

文章出處:【微信號:mcu168,微信公眾號:硬件攻城獅】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

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

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

    云服務器 Flexus X 實例:部署 Gitea,擁有自己的 Git 倉庫,管理本地代碼

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

    Flexus X 實例 C#/.Net Core 結合(git 代碼管理、docker 自定義鏡像)快速發布部署 - 讓你的項目飛起來~

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

    溫度振動變送器的概述及功能介紹

    制造業還是戰略性新型產業都離不開溫度振動變送器的支持。 一、溫度振動變送器的概述 溫度振動變送器集成了溫度傳感技術和振動傳感技術,可以測量工業設備的振動速度、表面溫度等參數。溫度振動變送器具有MEMS 芯片,采用嵌入式技
    的頭像 發表于 08-20 17:18 ?553次閱讀

    行程開關概述及應用介紹

    一、行程開關概述 行程開關,作為位置開關(限位開關)的一種,是廣泛應用于小電流環境中的主要控制電器。它通過機械運動部件的觸發來實現觸點的接通或斷開,進而控制電路,以實現特定的控制目標。這種開關機
    的頭像 發表于 08-16 17:31 ?1127次閱讀

    深度神經網絡概述及其應用

    通過模仿人類大腦神經元的連接方式和處理機制,設計多層神經元結構來處理復雜的數據模式,從而在各種數據驅動的問題中展現出強大的能力。本文將從深度神經網絡的基本概念、結構、工作原理、關鍵技術以及其在多個領域的應用等方面進行全面概述
    的頭像 發表于 07-04 16:08 ?1428次閱讀

    ubuntu下的vscode插件安裝idf時,總是找不到git,為什么?

    總是提示:Git is not found in current environment 但是我已經在setting.json下設置了\"git.path\": \"/bin/git\" 同行,命令行里查看
    發表于 06-21 07:16

    通過git命令獲取ESP8266_RTOS_SDK失敗如何解決?

    本人使用的硬件平臺為esp8266,開發環境為ubuntu22.04。在通過git命令獲取ESP8266_RTOS_SDK失敗,通過上網搜索嘗試了很多方法無效。具體情況如下
    發表于 06-07 07:26

    請問下使用IDF怎么做用git做版本控制?

    請問下使用IDF怎么做用git做版本控制?是保存自己應用部分的代碼還是整個SDK都要保存,但是整個框架都是官方下的,有沒必要保存,求各位大神告知下你們怎么處理的。
    發表于 06-06 07:15

    Git發布新版本 修補五處安全漏洞 包含嚴重遠程代碼執行風險

    CVE-2024-32002漏洞的嚴重性在于,黑客可通過創建特定的Git倉庫子模塊,誘騙Git將文件寫入.git/目錄,而非子模塊的工作樹。如此一來,攻擊者便能在克隆過程中植入惡意腳本,用戶幾乎無法察覺。
    的頭像 發表于 05-31 10:09 ?630次閱讀

    飛凌ElfBoard ELF 1板卡-ubuntu18.04 git安裝及基本使用

    1.安裝gitsudo apt-get install git 2.git初始化git init 3.設置用戶名和郵箱git config --global user.name \"你
    發表于 03-21 16:23

    光伏逆變器拓撲概述及關鍵技術

    光伏逆變器拓撲概述及關鍵技術
    的頭像 發表于 02-21 09:47 ?899次閱讀
    光伏逆變器拓撲<b class='flag-5'>概述及</b>關鍵技術

    藍牙 | 軟件:Git管理高通的ChipCode項目

    最近發現大家在高通chipcode網站上下載不了代碼,小編一直使用git的方式獲取新版本代碼,沒有遇到什么阻礙。于是小編到新主機上嘗試下載代碼的壓縮包和git代碼,都遇到了問題。由于壓縮包是高通自己
    的頭像 發表于 01-26 08:29 ?424次閱讀
    藍牙 | 軟件:<b class='flag-5'>Git</b>管理高通的ChipCode項目

    克服PLC編程的難題—基于Git的軟件

    Git是一種分布式版本控制系統,它可以記錄文件的修改歷史和版本變化,并可以支持多人協同開發。
    的頭像 發表于 01-22 09:30 ?979次閱讀
    克服PLC編程的難題—基于<b class='flag-5'>Git</b>的軟件

    Omniverse Nucleus概述及特征

    NVIDIA Omniverse? Nucleus 是 NVIDIA Omniverse 的數據庫和協作引擎。
    的頭像 發表于 01-17 09:22 ?847次閱讀
    Omniverse Nucleus<b class='flag-5'>概述及</b>特征
    主站蜘蛛池模板: 网友自拍区一区二区三区| 香蕉久久久久久狠狠色| 99插插插| 国产69精品久久| 神马影院午夜dy888| 直接黄91麻豆网站| 美女张开大腿让男人桶| 热久久这里只有精品| 免费的黄色片| 色国产在线视频一区| 深夜释放自己vlog糖心旧版本| 色香蕉在线视频| 美女在线看永久免费网址| 国产一级久久免费特黄| 开心激情小说| 国外免费一级| 欲色淫香| 久久久网站亚洲第一| 黄色xxxx| 国卡一卡二卡三免费网站| 亚洲精品视频区| 日本www网站| 国产资源站| 婷婷网址| 天天se天天cao综合网蜜芽| 黄色三级网站| 亚洲视频在线不卡| 亚洲香蕉毛片久久网站老妇人| 日韩一级欧美一级在线观看| 色老久久精品偷偷鲁一区| 女人张开腿男人桶| www.亚洲色图.com| 久久午夜视频| 亚洲狠狠狠一区二区三区| 香蕉视频在线免费播放| 免费看一级视频| 中文在线天堂网www| 午夜毛片不卡高清免费| 国产紧缚jvid| 国语一区| 欧美日韩a级a|