Source From Here
在 Git 裡,不管是刪除檔案或是變更檔名,對 Git 來說都是一種「修改」。
刪除檔案
直接砍
你可以使用系統指令 rm 或是檔案總管之類的工具來刪除檔案,例如:
可以看到 welcome.html 這個檔案目前的狀態是 deleted。如果你確定這是你想做的,就可以把這次的「修改」加到暫存區:
它現在的狀態是 staged,而且已被加至暫存區,所以接下來就可以進行 Commit 了。我知道「把刪除檔案加到暫存區」這件事感覺有點不太直覺,就把「刪除檔案」也當做是一種「修改」看待就行了。
請 Git 幫你砍
像這樣先 rm 刪除然後再 git rm 加入暫存區的兩段式動作,事實上可以直接使用 git rm 指令. 首先來救回 welcome.html 檔案:
接著直接使用 git rm 移除:
它就直接在暫存區了,可以少做一個步驟。
加上 –cached 參數
不管是系統的 rm 或是 git rm 指令,都會真的把這個檔案從工作目錄裡刪掉,但如果只是「我不是真的想把這個檔案刪掉,只是不想讓這個檔案再被 Git 控管了」的話,可以加上 --cached 參數:
welcome.html 的狀態從原本已經在 Git 目錄裡的 tracked 變成 Untracked 了。你依舊需要 commit 來將 welcome.html 從 Git 版本管控移除:
接著你可以參考 【狀況題】有些檔案我不想放在 Git 裡面 讓 welcome.html 不再出現 untracked file 中.
變更檔名
直接改名
跟刪除檔案一樣,變更檔名也是一種「修改」,所以操作上其實也是差不多的:
雖然只是改檔名,但對 Git 來說會被認為是兩個動作,一個是刪除 hello.html 檔案,一個是新增 world.html 檔案(變成 Untracked 狀態)。接著繼續使用 git add 指令把這些異動加至暫存區:
因為檔案的內容沒有改變,Git 猜得出來這個只是單純的改名字,所以現在它的狀態變成 renamed 了。
請 Git 幫你改名
跟前面的 git rm 一樣,Git 也有提供類似的指令 git mv 可以讓你少做一步:
【冷知識】其實 Git 根本不在乎你的檔案叫什麼名字!
Git 是根據檔案的「內容」去算出那個 SHA-1 的值,所以 Git 不是很在乎你的檔案叫什麼名字,只在乎檔案的內容是什麼。所以當你進行更改檔名的時候,Git 並沒有為此做出一個新的 Blob 物件,而僅是指向原來舊的那顆 Blob 物件。但因為檔名變了,所以會為此做出一顆新的 Tree 物件喔。如果這些 Git 物件還不清楚它們是幹嘛的,在後面的「【超冷知識】在 .git 目錄裡有什麼東西?Part 1」章節會有詳細的說明
This is a blog to track what I had learned and share knowledge with all who can take advantage of them
標籤
- [ 英文學習 ]
- [ 計算機概論 ]
- [ 深入雲計算 ]
- [ 雜七雜八 ]
- [ Algorithm in Java ]
- [ Data Structures with Java ]
- [ IR Class ]
- [ Java 文章收集 ]
- [ Java 代碼範本 ]
- [ Java 套件 ]
- [ JVM 應用 ]
- [ LFD Note ]
- [ MangoDB ]
- [ Math CC ]
- [ MongoDB ]
- [ MySQL 小學堂 ]
- [ Python 考題 ]
- [ Python 常見問題 ]
- [ Python 範例代碼 ]
- [心得扎記]
- [網路教學]
- [C 常見考題]
- [C 範例代碼]
- [C/C++ 範例代碼]
- [Intro Alg]
- [Java 代碼範本]
- [Java 套件]
- [Linux 小技巧]
- [Linux 小學堂]
- [Linux 命令]
- [ML In Action]
- [ML]
- [MLP]
- [Postgres]
- [Python 學習筆記]
- [Quick Python]
- [Software Engineering]
- [The python tutorial]
- 工具收集
- 設計模式
- 資料結構
- ActiveMQ In Action
- AI
- Algorithm
- Android
- Ansible
- AWS
- Big Data 研究
- C/C++
- C++
- CCDH
- CI/CD
- Coursera
- Database
- DB
- Design Pattern
- Device Driver Programming
- Docker
- Docker 工具
- Docker Practice
- Eclipse
- English Writing
- ExtJS 3.x
- FP
- Fraud Prevention
- FreeBSD
- GCC
- Git
- Git Pro
- GNU
- Golang
- Gradle
- Groovy
- Hadoop
- Hadoop. Hadoop Ecosystem
- Java
- Java Framework
- Java UI
- JavaIDE
- JavaScript
- Jenkins
- JFreeChart
- Kaggle
- Kali/Metasploit
- Keras
- KVM
- Learn Spark
- LeetCode
- Linux
- Lucene
- Math
- ML
- ML Udemy
- Mockito
- MPI
- Nachos
- Network
- NLP
- node js
- OO
- OpenCL
- OpenMP
- OSC
- OSGi
- Pandas
- Perl
- PostgreSQL
- Py DS
- Python
- Python 自製工具
- Python Std Library
- Python tools
- QEMU
- R
- Real Python
- RIA
- RTC
- Ruby
- Ruby Packages
- Scala
- ScalaIA
- SQLAlchemy
- TensorFlow
- Tools
- UML
- Unix
- Verilog
- Vmware
- Windows 技巧
- wxPython
訂閱:
張貼留言 (Atom)
[Git 常見問題] error: The following untracked working tree files would be overwritten by merge
Source From Here 方案1: // x -----删除忽略文件已经对 git 来说不识别的文件 // d -----删除未被添加到 git 的路径中的文件 // f -----强制运行 # git clean -d -fx 方案2: 今天在服务器上 gi...
-
前言 : 為什麼程序管理這麼重要呢?這是因為: * 首先,本章一開始就談到的,我們在操作系統時的各項工作其實都是經過某個 PID 來達成的 (包括你的 bash 環境), 因此,能不能進行某項工作,就與該程序的權限有關了。 * 再來,如果您的 Linux 系統是個...
-
屬性 : 系統相關 - 檔案與目錄 語法 : du [參數] [檔案] 參數 | 功能 -a | 顯示目錄中個別檔案的大小 -b | 以bytes為單位顯示 -c | 顯示個別檔案大小與總和 -D | 顯示符號鏈結的來源檔大小 -h | Hum...
-
來源自 這裡 說明 : split 是 Perl 中非常有用的函式之一,它可以將一個字串分割並將之置於陣列中。若無特別的指定,該函式亦使用 RE 與 $_ 變數 語法 : * split /PATTERN/,EXPR,LIMIT * split /...
沒有留言:
張貼留言