git使用詳解和示例

什么是 Git?

Git 是一個 分布式版本控制系統(DVCS),用于跟蹤文件的變化,協調多人協作開發。由 Linus Torvalds 開發,用于管理 Linux 內核代碼。


Git 的核心概念

名稱說明
工作區 (Working Directory)你看到的項目目錄。你在這里新增、編輯、刪除文件。
暫存區 (Staging Area / Index)暫時保存將要提交的修改(git add 的作用)。
本地倉庫 (Local Repository)Git 數據庫,保存提交歷史(執行 git commit 存入)。
遠程倉庫 (Remote Repository)如 GitHub/GitLab/Codeup 上的共享倉庫。

在這里插入圖片描述

Git 文件的四種狀態

Untracked → Staged → Committed↑           ↓Modified     (Reset)
  1. Untracked:新文件,未被 Git 管理。
  2. Modified:已修改但未添加到暫存區。
  3. Staged:使用 git add 添加后進入。
  4. Committed:用 git commit 記錄后存入倉庫歷史。

Git 安裝與配置

安裝

  • Windows: Git for Windows
  • macOS: brew install git
  • Linux: sudo apt install git

全局配置

git config --global user.name "Your Name"
git config --global user.email "you@example.com"
git config --global core.editor "code"  # 設置默認編輯器

常用 Git 命令(分類整理)

1. 倉庫管理

git init                     # 初始化一個倉庫
git clone <url>             # 克隆遠程倉庫

2. 文件操作

git status                  # 查看當前狀態
git add <file|.>            # 添加到暫存區
git commit -m "描述"        # 提交更改
git rm <file>               # 刪除文件并加入提交
git mv <old> <new>          # 重命名文件

3. 查看歷史

git log                     # 提交歷史
git log --oneline           # 簡潔視圖
git show <commit>           # 查看某次提交的詳細內容
git diff                    # 當前工作區 vs 暫存區
git diff --cached           # 暫存區 vs 上次提交

4. 分支管理

git branch                  # 查看分支
git branch <name>           # 創建分支
git checkout <name>         # 切換分支
git checkout -b <name>      # 創建并切換分支
git merge <branch>          # 合并分支
git branch -d <name>        # 刪除分支

5. 遠程操作

git remote add origin <url>         # 添加遠程倉庫
git fetch                           # 獲取遠程更新
git pull origin <branch>            # 拉取遠程分支并合并
git push origin <branch>            # 推送本地分支
git push -u origin <branch>         # 設置默認推送分支

6. 回退與重置

git checkout -- <file>             # 撤銷對某文件的修改
git reset HEAD <file>              # 取消暫存某文件
git reset --soft HEAD~1            # 回退上一次提交,保留修改
git reset --hard HEAD~1            # 強制回退,丟棄修改

7. 標簽管理

git tag v1.0
git tag -a v1.0 -m "發布版本"
git show v1.0
git push origin v1.0

Git 工作流示例(推薦流程)

示例:多人協作開發流程

  1. 克隆項目:
git clone https://github.com/user/project.git
cd project
  1. 創建分支開發:
git checkout -b feature/login
  1. 編輯代碼,提交:
git add .
git commit -m "feat: 完成登錄功能"
  1. 合并分支:
git checkout main
git pull
git merge feature/login
git push
  1. 清理:
git branch -d feature/login

.gitignore 文件

.gitignore 用于告訴 Git 忽略哪些文件:

# 忽略編譯文件
*.o
*.exe
build/# 忽略日志
*.log# 忽略 IDE 文件
.vscode/
.idea/

高級命令與技巧

功能命令
臨時保存修改git stash / git stash pop
查看某行修改歷史git blame filename
圖形化查看歷史gitk / git log --graph
切換到舊版本git checkout <commit>
撤銷提交但保留文件git reset --soft HEAD~1
Git 別名git config --global alias.co checkout

Git 圖形工具推薦

工具名說明
GitHub Desktop適合新手
Sourcetree免費強大,功能全面
TortoiseGitWindows 上右鍵菜單支持
GitKraken界面漂亮,專業團隊使用
VS Code Git 插件編輯器直接操作 Git

Git 練習網站推薦

  • https://learngitbranching.js.org
  • https://git-school.github.io/visualizing-git

小結

類型命令
初始化/克隆git init, git clone
暫存/提交git add, git commit
查看狀態git status, git log
分支管理git branch, git checkout, git merge
遠程操作git push, git pull, git remote
撤銷/回退git reset, git checkout, git stash

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/88941.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/88941.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/88941.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

深度學習的引出

雖然我們的神經?絡給出了令?印象深刻的表現&#xff0c;但這樣的表現帶有?分神秘 ?絡中的權重和偏置是被?動發現的。這意味著我們不能?即解釋?絡怎么做的、做了什么。我們能否找 到?些?法來理解我們的?絡通過什么原理分類?寫數字&#xff1f;并且&#xff0c;在知道…

GEO(生成式引擎優化)—— 內容創作者與企業的生死新戰場

在搜索引擎優化&#xff08;SEO&#xff09;定義了互聯網信息獲取規則數十年后&#xff0c;一場由生成式人工智能&#xff08;AIGC&#xff09;驅動的風暴正悄然重塑整個格局。當ChatGPT、Claude、Gemini等AI助手能夠直接生成整合后的答案&#xff0c;而非僅僅提供鏈接列表時&a…

混合密度模型GMM的似然函數(二)

設 Θ { π k , θ k } k 1 K \varTheta \{ \pi_k, \boldsymbol {\theta}_k \}_{k1}^{K} Θ{πk?,θk?}k1K?為參數向量&#xff0c; X { x 1 , ? , x n } \mathcal {X} \{ {\bm x}_1, \cdots, {\bm x}_n \} X{x1?,?,xn?}為觀測數據&#xff0c;給定數據點的獨立性&a…

selenium元素定位

當我們可以打開瀏覽器后我們如果想要進行web測試我們自然要對網頁的一些功能進行單獨拿出來進行測試&#xff0c;但是我們要怎么才能拿到我們想要的元素&#xff0c;并且對其進行操作呢。 我們就以百度主頁的輸入框為例&#xff0c;如果我們想要王輸入框中輸入一些內容我們就需…

2025第十五屆上海生物發酵展:江蘇健達干燥盛裝赴會

2025 年 8 月 7 - 9 日&#xff0c;上海新國際博覽中心將迎來一場生物發酵行業的盛會 —— 第 15 屆上海國際生物發酵產品與技術裝備展覽會&#xff08;BIOCHINA 2025&#xff09;。作為國內干燥設備領域的領軍企業&#xff0c;江蘇健達干燥工程有限公司受邀盛裝參展&#xff0…

【效率工具】單機游戲修改方案:輕量管理器+全能平臺組合

大家好&#xff01;今天我要給大家介紹兩款超級實用的軟件&#xff0c;專門為喜歡玩單機游戲的小伙伴們準備。 一、風靈月影管理器 不想滿網翻修改器&#xff1f;這個 27M 的小工具直接幫你一鍵搞定&#xff0c;這款軟件是由B站UP鴉無量 開發。 收錄上千款游戲補丁&#xff0c;…

七天學會SpringCloud分布式微服務——01——基礎概念

重點是復習體系&#xff0c;從今天6.24開始&#xff0c;確保轉化為自己的東西心平氣和&#xff0c;腳踏實地學習的是尚硅谷微服務 1、從單體架構到集群架構再到分布式架構 單體架構 就是 所有的功能&#xff08;服務&#xff09;模塊 都部署在同一臺服務器&#xff08;一臺服…

三分鐘學會利用deepseek將復雜信息轉換成可視化圖表

數據可視化是傳達復雜信息的重要手段。通過將數據轉化為直觀的圖表、圖形和交互式界面,我們可以更高效地理解信息、發現趨勢并做出決策。對于普通人來說,要將數據可視化可謂千難萬難。但在AI工具飛速發展的今天,這個過程將會變得非常簡單。今天分享的內容就是如何使用生成式…

PDF處理控件Spire.PDF系列教程:Python中快速提取PDF文本、表格、圖像及文檔信息

在 Python 中讀取 PDF 文檔是實現文檔自動化、內容分析和數據提取的基礎操作之一。無論你處理的是合同、報告、發票&#xff0c;還是科研論文&#xff0c;能夠通過代碼訪問 PDF 內容&#xff0c;不僅能節省時間&#xff0c;還能帶來更高效的處理流程。 要在 Python 中準確提取…

微軟人工智能證書AI-102 | 如何快速通過?

微軟 AI-102 考試&#xff0c;全稱 “Designing and Implementing a Microsoft Azure AI Solution”&#xff0c;是微軟推出的用于驗證考生在 Azure 平臺上設計和實施 AI 解決方案核心能力的認證考試。以下是具體介紹&#xff1a; 考試描述&#xff1a; 考試主要衡量考生實施計…

github使用指南

1、生成SSH密鑰對 ssh-keygen -t ed25519 -C "你的github郵箱"然后根據提示保存路徑&#xff0c;設置密碼 2、將公鑰添加到github cat ~/.ssh/id_ed25519.pub復制輸出內容。 在gihub中點擊New SSH Key&#xff0c;添加密鑰 3、配置git使用SSH地址 git remote se…

AD22以上的基礎操作

1.檢測創建的原理圖器件庫 2.原理圖頁加大 Size&#xff1a;常規和自定義 推薦可視化柵格100mil 快捷鍵VG 3.原理圖器件器件號排序 自動排序&#xff1a;快捷鍵TAA 先解鎖 4.BOM(Bill of Material)物料表導出 description描述&#xff1a;類似精度。 導出各種類型bom表 5…

FastAPI技術深度解析與實戰指南

導讀&#xff1a;在Python Web開發領域經歷了Django和Flask多年統治后&#xff0c;FastAPI的崛起正在重新定義API開發的技術標準。這篇深度技術解析將為開發者揭示FastAPI如何通過獨特的架構設計解決傳統框架的核心痛點。 傳統Python Web框架在面對高并發場景時暴露出明顯的性能…

Python 可迭代的對象、迭代器 和生成器(何時使用生成器表達式)

何時使用生成器表達式 在示例 10-16 中&#xff0c;為了實現 Vector 類&#xff0c;我用了幾個生成器表達 式&#xff0c;eq、hash、abs、angle、angles、format、add 和 __mul__ 方法中各有一個生成器表達式。在這些方法中使用列表推 導也行&#xff0c;不過立即返回的列表要…

復習和預習(C++)答案解析

填空題答案及解釋 在 for 循環實現累加時&#xff0c;通常在循環上方初始化累加器變量&#xff0c;如 int m ______。 答案&#xff1a;0 解釋&#xff1a;累加器需從 0 開始&#xff0c;才能正確累積后續值的總和。 switch 語句根據表達式的值與各個______后的常量表達式進行…

uniapp處理后端返回的html字符串

前言&#xff1a;采用v-html方法處理 1.處理前 <html><head><meta http‐equiv"Content‐Type" content"text/html; charsetUTF-8"></head><body><form ?<input type"submit" value"立刻提交"…

如何在 Ubuntu 上通過終端或在 VirtualBox 中安裝 GCC

無論你是正在編譯 C 程序,還是在 Linux 上從源代碼構建軟件,GNU 編譯器集合(GCC)都是每位 Linux 開發者需要的工具之一,因為它能夠編譯 C、C++,甚至 Fortran、Ada 等其他語言。但如果你想知道如何在 Ubuntu 上安裝 GCC 并設置它來編譯代碼,別擔心——你來對地方了。 本…

Mac python3.12 執行pip/pip3異常externally-managed-environment

環境&#xff1a;Mac、Python3.12.x版本&#xff08;3.12.5&#xff09; 問題&#xff1a;執行pip install xyz 后出現異常&#xff1a; error: externally-managed-environment This environment is externally managed ╰─> To install Python packages system-wide,…

最后的生還者2:重制版 免安 中文離線運行版+整合包

最后的生還者2&#xff1a;重制版 1.4.10515.0636 免安 中文離線運行版整合包 最低配置: 需要 64 位處理器和操作系統 操作系統: Windows 10/11 64-bit (version 1909 or higher) 處理器: Intel Core i3-8100, AMD Ryzen 3 1300X 內存: 16 GB RAM 顯卡: NVIDIA GeForce GTX 16…

【Arm】DS如何應用腳本文件實現調試

1、 文檔目標 在現代嵌入式開發中&#xff0c;調試工具的選擇和使用對開發效率和產品質量有著至關重要的影響。Arm Development Studio&#xff08;簡稱ArmDS&#xff09;作為一款功能強大的集成開發環境&#xff08;IDE&#xff09;&#xff0c;專為基于ARM架構的處理器設計&…