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
  • Dapr Outbox 是1.12中的功能。 本文只介紹Dapr Outbox 執行流程,Dapr Outbox基本用法請閱讀官方文檔 。本文中appID=order-processor,topic=orders 本文前提知識:熟悉Dapr狀態管理、Dapr發佈訂閱和Outbox 模式。 Outbo ...
  • 引言 在前幾章我們深度講解了單元測試和集成測試的基礎知識,這一章我們來講解一下代碼覆蓋率,代碼覆蓋率是單元測試運行的度量值,覆蓋率通常以百分比表示,用於衡量代碼被測試覆蓋的程度,幫助開發人員評估測試用例的質量和代碼的健壯性。常見的覆蓋率包括語句覆蓋率(Line Coverage)、分支覆蓋率(Bra ...
  • 前言 本文介紹瞭如何使用S7.NET庫實現對西門子PLC DB塊數據的讀寫,記錄了使用電腦模擬,模擬PLC,自至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1.Windows環境下鏈路層網路訪問的行業標準工具(WinPcap_4_1_3.exe)下載鏈接:http ...
  • 從依賴倒置原則(Dependency Inversion Principle, DIP)到控制反轉(Inversion of Control, IoC)再到依賴註入(Dependency Injection, DI)的演進過程,我們可以理解為一種逐步抽象和解耦的設計思想。這種思想在C#等面向對象的編 ...
  • 關於Python中的私有屬性和私有方法 Python對於類的成員沒有嚴格的訪問控制限制,這與其他面相對對象語言有區別。關於私有屬性和私有方法,有如下要點: 1、通常我們約定,兩個下劃線開頭的屬性是私有的(private)。其他為公共的(public); 2、類內部可以訪問私有屬性(方法); 3、類外 ...
  • C++ 訪問說明符 訪問說明符是 C++ 中控制類成員(屬性和方法)可訪問性的關鍵字。它們用於封裝類數據並保護其免受意外修改或濫用。 三種訪問說明符: public:允許從類外部的任何地方訪問成員。 private:僅允許在類內部訪問成員。 protected:允許在類內部及其派生類中訪問成員。 示 ...
  • 寫這個隨筆說一下C++的static_cast和dynamic_cast用在子類與父類的指針轉換時的一些事宜。首先,【static_cast,dynamic_cast】【父類指針,子類指針】,兩兩一組,共有4種組合:用 static_cast 父類轉子類、用 static_cast 子類轉父類、使用 ...
  • /******************************************************************************************************** * * * 設計雙向鏈表的介面 * * * * Copyright (c) 2023-2 ...
  • 相信接觸過spring做開發的小伙伴們一定使用過@ComponentScan註解 @ComponentScan("com.wangm.lifecycle") public class AppConfig { } @ComponentScan指定basePackage,將包下的類按照一定規則註冊成Be ...
  • 操作系統 :CentOS 7.6_x64 opensips版本: 2.4.9 python版本:2.7.5 python作為腳本語言,使用起來很方便,查了下opensips的文檔,支持使用python腳本寫邏輯代碼。今天整理下CentOS7環境下opensips2.4.9的python模塊筆記及使用 ...