git-github遠程倉庫以及git的進階使用

来源:https://www.cnblogs.com/heymar/archive/2022/04/29/16207549.html
-Advertisement-
Play Games

註意保存自己的筆記吧,看來這個typora還是有點bug,居然還被我碰到了,今天突然死機,重啟電腦後,看我自動保存的裡面居然沒有後來連上網了又有了,這就不說了嘛,但是命名文件有幾kb的大小,為什麼我一點開就是空白,我又重新開始學了,重新做一份筆記,還好代碼量不是很大,看來以後時常要ctrl+s常按了 ...


註意保存自己的筆記吧,看來這個typora還是有點bug,居然還被我碰到了,今天突然死機,重啟電腦後,看我自動保存的裡面居然沒有後來連上網了又有了,這就不說了嘛,但是命名文件有幾kb的大小,為什麼我一點開就是空白,我又重新開始學了,重新做一份筆記,還好代碼量不是很大,看來以後時常要ctrl+s常按了。

一.開源相關概念

1. 什麼是開源

開放源代碼,代碼公開任何人可以去使用、修改的。

2. 開源許可協議

  • GPL:具有傳染性的一種協議,項目有這個協議了,項目中的任何項目都必須使用這個協議,他的特點是不允許修改和衍生的代碼作為閉源的商業軟體發佈和銷售(linux就是該協議,所以他下麵的項目都要採用這個協議)
  • MIT:限制最少協議,在修改後的代碼或者發行包中包含原作者許可信息即可。(jquery、node.js)

3. 開源項目托管平臺

  • github
  • gitlab
  • gitee

二.github

1. 創建空白遠程倉庫

image-20220429133721527

2. 遠程倉庫兩種訪問方式

  • HTTPS:零配置,但是每次訪問倉庫時都要輸入賬號密碼

    還是需要在本地裡面創建項目並且放入暫存放入倉庫的地步

    image-20220429133905583

  • SSH:額外配置,但是不再需要輸入賬號密碼(推薦)

    先要生成ssh Key

    image-20220429134328837

    然後配置github

    image-20220429134439072

    測試是否配置成功

    image-20220429134543279

    SSH上傳倉庫(同樣需要提交本地倉庫)

    創建一個新的倉庫,然後點擊ssh鏈接按照步驟即可

3. 新修改的項目如何上傳?

直接git push 即可

image-20220429134202044

image-20220429134233119

4.將遠程倉庫克隆到本地

git clone
image-20220429135124112

三.分支

1. 概念

我理解的意思就是相當於平行宇宙,這個世界的你在學git,那個世界的你在學vue,這就是兩個分支,未來某一天還可能會合併,git和vue我都會。

2. master(main)主分支

註意:2020年十月開始github就將主分支也就是預設分支改為了main,在我們的老倉庫看的到還是master的主分支

在我們初始化git init本地倉庫的時候就會自動創建子一個master主分支出來。

image-20220429135453779

它的作用是用來保存和記錄整個項目已完成的功能代碼,所以一般不推薦程式員直接去修改master主分支上的代碼,因為這樣風險太高容易導致項目崩潰。

3. 功能分支

也就是主分支上分叉出來的各個功能的分支,完成後合併到主分支上。

4. 查看分支列表

git branch

image-20220429135815218

5. 創建新分支

git branch 分支名稱

image-20220429140022071

註意:只是創建並不會到這個分支上

6. 切換分支

git checkout 分支名稱

image-20220429140214498

7. 分支的快速創建和切換

git checkout -b 分支名稱

這個代碼可以直接創建又馬上切換到創建的分支上,其實就相當於把branch簡寫了。

8. 合併分支

image-20220429140356710

好了剛纔的筆記終結到這裡就結束了,又學了一編,我來詳細闡述一下流程

  • 先創建一個項目,在項目裡面打開終端切換到login分支在這個分支裡面完成登錄需求

    註意:我們雖然是一初始化就有這麼一個master主分支,但是要上傳文件後才能在git branch裡面看到他才能切換他,所以第一次項目的創建還要先本地上傳一次倉庫

    image-20220429142525229

    image-20220429141429760

    註意我們的我們此時的文件都有大小的

  • 切換回主分支,註意看文件大小

    image-20220429142911369

    image-20220429142949616

9.刪除分支

當我們把功能分支代碼合併進去後就可以刪除了,因為完成了功能業合併了進去這個分支就沒用了

git branch -d 分支名稱 需要在另外的分支上刪除

image-20220429143240031

註意:當分支沒有合併到主分支的時候刪除會失敗,因為裡面有文件沒有合併刪了就沒得了,這個時候要強制刪除 -D

10.遇到衝突時的分支合併

當我們在兩個不同的分支裡面對同一個文件都做了修改都上傳了本地倉庫,這個時候再來合併就會報錯,這個時候需要我們手動的去找到發生錯誤的文件然後解決衝突之後在執行git add 和 git commit

兩邊都輸入了一些新代碼並上傳倉庫

image-20220429145640706

合併報錯了,這個時候應該手動打開報錯的文件,進行手動修改

image-20220429145758818

這個時候將這個文件用vscode打開可以選擇以哪個的為準進行存儲

image-20220429155443140

修改完畢放入暫存區,上傳倉庫,就可以合併進來了

image-20220429155630087

11.將本地分支推送到遠程倉庫

​ 第一次需要執行以下代碼:

image-20220429155838363

遠程分支名稱沒有的話定義的遠程分支名字相當於下定義;預設遠程倉庫別名就為origin
​ 註意:第一次把本地分支推送遠程倉庫需要-u參數,後面直接git push即可

12.查看遠程倉庫分支列表


git remote show 遠程倉庫名

image-20220429160739782

13.跟蹤分支

​ 即從遠程倉庫將遠程分支下載到本地倉庫中。
image-20220429160934817
註意:這裡是兩種方法前面兩句是把遠程分支下下來以pay命名;後面兩句話是將遠程分支重命名下載下來
方法一:
image-20220429161332870
image-20220429161353242

方法二:
image-20220429161541682

14.拉取遠程分支最新代碼

git pull

github線上編輯
image-20220429170533187
此時的大小
image-20220429170634334
pull後的代碼大小
image-20220429171030647

15.刪除遠程分支

image-20220429171110279
image-20220429171241199


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 最近需要使用mysql8.0版本,但是原本的mysql5.7版本已經被多個服務依賴,於是想想能不能同一臺伺服器裝多個版本的mysql,一查確實可行,這裡做一個記錄方便自己後期回憶 閱讀本文前請註意!!! 本文是幫助您建立在mysql5.7版本已經安裝完成併在運行中,另外安裝配置mysql8.0版本 ...
  • 事務概述 當多個用戶訪問同一份數據時,一個用戶在更改數據的過程中,可能有其他用戶同時發起更改請求,為保證資料庫記錄的更新從一個一致性狀態變為另外一個一致性狀態,使用事務處理是非常必要的,事務具有以下四個特性: 原子性(Atomicity):事務中所有操作視為一個原子單位,即對事務所進行的數據修改等操 ...
  • Hadoop是什麼 大白話,Hadoop是個存儲數據,計算數據的分散式框架。核心組件是HDFS、MapReduce、Yarn。 HDFS:分散式存儲 MapReduce:分散式計算 Yarn:調度MapReduce 現在為止我們知道了HDFS、MapReduce、Yarn是幹啥的,下麵通過一張圖再來 ...
  • Mysql 連續數據分組 思路是使用變數 逐行將上行和當前行進行對比 條件滿足則生成分組的編號,再根據分組條件和分組編號分組就可以。 ...
  • 主從複製 這是《Redis設計與實現》系列的文章,系列導航:Redis設計與實現筆記 SLAVEOF 新舊複製功能 舊版複製功能 舊版複製功能的實現為 同步 和 命令傳播: 當剛連上Master時,要做一次全同步: sequenceDiagram participant Slave particip ...
  • 移動互聯網的發展給人們的社交和娛樂方式帶來了很大的改變,以vlog、短視頻等為代表的新興文化樣態正受到越來越多人的青睞。同時,隨著AI智能、美顏修圖等功能在圖像視頻編輯App中的應用,促使視頻編輯效率和視頻效果得到了很大的提升,也讓視頻應用場景更加豐富。 當前剪輯產品功能多樣、素材豐富,但是開發周期 ...
  • 4月28日晚上19點,知識賦能第五期第二節課《如何成為OpenHarmony社區貢獻達人?》,在OpenHarmony開發者成長計劃社群內成功舉行。 ...
  • 前言 ​ 分析用戶行為,需要標識用戶。選擇合適的用戶標識,可以提高用戶行為分析的準確性,尤其是是漏洞留存分析等,這些和用戶分析相關的功能。對於唯一標識一個用戶,我們需要考慮兩種場景。 用戶登陸之前如何標識 用戶登陸之後如何標識 一、登陸之前 業界一般使用 iOS 設備的某個特定屬性或者某幾個特定屬性 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文將以 C# 語言來實現一個簡單的布隆過濾器,為簡化說明,設計得很簡單,僅供學習使用。 感謝@時總百忙之中的指導。 布隆過濾器簡介 布隆過濾器(Bloom filter)是一種特殊的 Hash Table,能夠以較小的存儲空間較快地判斷出數據是否存在。常用於允許一定誤判率的數據過濾及防止緩存 ...
  • 目錄 一.簡介 二.效果演示 三.源碼下載 四.猜你喜歡 零基礎 OpenGL (ES) 學習路線推薦 : OpenGL (ES) 學習目錄 >> OpenGL ES 基礎 零基礎 OpenGL (ES) 學習路線推薦 : OpenGL (ES) 學習目錄 >> OpenGL ES 轉場 零基礎 O ...
  • 「簡單有價值的事情長期堅持做」 這是成功最簡單,但也最難學的秘訣。不經過訓練,人很難意識到時間複利的威力。 仙劍奇俠傳的「十里坡劍神」和金庸群俠傳的「十級野球拳」,就是簡單的事情持之以恆反覆做,最後就有巨大的威力 唐家三少成為網文收入第一,最重要的一步是十四年從未斷日更 這樣的案例很多,一開始可能成 ...
  • 迎面走來了你的面試官,身穿格子衫,挺著啤酒肚,髮際線嚴重後移的中年男子。 手拿泡著枸杞的保溫杯,胳膊夾著MacBook,MacBook上還貼著公司標語:“我愛加班”。 面試開始,直入正題。 面試官: 看你簡歷上面寫著精通MySQL,我先問你事務的特性是什麼? 老生常談,這個還有誰不會背的嗎? 我: ...
  • 基礎知識 python是一門腳本語言,它是解釋執行的。 python使用縮進做為語法,而且python2環境下同一個py文件中不能同時存在tab和空格縮進,否則會出錯,建議在IDE中顯示縮進符。 python在聲明變數時不寫數據類型,可以type(xx)來獲取欄位的類型,然後可以int(),list ...
  • 為什麼要多線程下載 俗話說要以終為始,那麼我們首先要明確多線程下載的目標是什麼,不外乎是為了更快的下載文件。那麼問題來了,多線程下載文件相比於單線程是不是更快? 對於這個問題可以看下圖。 橫坐標是線程數,縱坐標是使用對應線程數下載對應文件時花費的時間,藍橙綠代表下載文件的大小,每個線程下載對應文件2 ...
  • 詳細講解python爬蟲代碼,爬微博搜索結果的博文數據。 爬取欄位: 頁碼、微博id、微博bid、微博作者、發佈時間、微博內容、轉發數、評論數、點贊數。 爬蟲技術: 1、requests 發送請求 2、datetime 時間格式轉換 3、jsonpath 快速解析json數據 4、re 正則表達式提... ...
  • 背景: 一般我們可以用HashMap做本地緩存,但是HashMap功能比較弱,不支持Key過期,不支持數據範圍查找等。故在此實現了一個簡易的本地緩存,取名叫fastmap。 功能: 1.支持數據過期 2.支持等值查找 3.支持範圍查找 4.支持key排序 實現思路: 1.等值查找採用HashMap2 ...
  • 目錄 一.簡介 二.效果演示 三.源碼下載 四.猜你喜歡 零基礎 OpenGL (ES) 學習路線推薦 : OpenGL (ES) 學習目錄 >> OpenGL ES 基礎 零基礎 OpenGL (ES) 學習路線推薦 : OpenGL (ES) 學習目錄 >> OpenGL ES 轉場 零基礎 O ...
  • 本章是系列文章的第八章,用著色演算法進行寄存器的分配過程。 本文中的所有內容來自學習DCC888的學習筆記或者自己理解的整理,如需轉載請註明出處。周榮華@燧原科技 寄存器分配 寄存器分配是為程式處理的值找到存儲位置的問題 這些值可以存放到寄存器,也可以存放在記憶體中 寄存器更快,但數量有限 記憶體很多,但 ...