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
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...