Rumah >hujung hadapan web >tutorial js >Ditch Git Checkout: Gunakan Git Switch dan Git Restore Sebaliknya

Ditch Git Checkout: Gunakan Git Switch dan Git Restore Sebaliknya

Barbara Streisand
Barbara Streisandasal
2024-10-14 13:28:05945semak imbas

Jika anda menggunakan Git dalam kerja harian anda, git checkout ialah arahan biasa. Ia sering digunakan untuk menukar cawangan dan jika anda melihat dokumentasi, anda boleh melihat frasa "tukar cawangan atau pulihkan fail pokok yang berfungsi". Tetapi UNIX sepatutnya Lakukan Satu Perkara dan Lakukan Dengan Baik. Ini mengelirukan, jadi Git 2.23 membawa sepasang arahan untuk menggantikannya.


Sebelum memperkenalkan cara ia berfungsi, kita perlu memahami secara ringkas konsep Git yang berkaitan.

  • Salinan berfungsi (fail pokok berfungsi): Ia merujuk kepada fail dalam repositori yang muncul pada cakera keras.

  • Indeks (kawasan pementasan atau cache): ia merujuk kepada anda mempunyai git add-ed, atau, apa yang akan dilakukan jika anda menjalankan git commit.

  • KEPALA: Ia merujuk kepada cawangan "semasa" atau "aktif", apabila kami perlu menyemak cawangan (merujuk kepada percubaan anda untuk memadankan cawangan dengan apa yang terdapat dalam salinan kerja), hanya satu yang boleh diperiksa pada satu masa.

git checkout boleh mendaftar keluar cawangan atau mencipta cawangan baharu dan mendaftar keluar ke dalamnya:

# Switched to branch 'test'
$ git checkout test

# Switched to a new branch 'test'
$ git checkout -b test

# Switch back to the previous branch
$ git checkout -

# Switched to a commit
$ git checkout master~1

Dan suis git digunakan untuk mengambil alih berkaitan cawangan, jadi ia juga boleh melakukan:

# Switched to branch 'test'
$ git switch test

# Switched to a new branch 'test'
$ git switch -c test

# Switch back to the previous branch
$ git switch -

# Switched to a commit
$ git switch -d master~1

Dan seperti yang kami katakan pada mulanya, git checkout juga boleh memulihkan fail pokok yang berfungsi. Bahagian ciri ini diambil alih oleh git restore.

Pada masa lalu, kita boleh menggunakan git checkout -- main.c untuk memulihkan fail pokok yang berfungsi daripada indeks, sintaksnya ialah git checkout [treeish] -- , di mana treeish boleh ditentukan sebagai sumber . Contoh mudah:

# Restoring the working tree from the index
$ git checkout -- ./main.c

# Restoring index content from HEAD
$ git reset -- ./main.c

# Restoring the working tree and index from HEAD
$ git checkout HEAD -- ./main.c

Perhatikan bahawa apabila memulihkan kandungan indeks daripada HEAD, kami hanya boleh menggunakan git reset dan git checkout tidak mempunyai pilihan yang sepadan.

Tunjukkan dengan graf:

Ditch Git Checkout: Use Git Switch and Git Restore Instead

git restore memudahkan untuk menentukan fail mana yang akan dipulihkan dan tempat ia akan dipulihkan. Pilihan berikut menentukan lokasi pemulihan:

-W
--worktree
-S
--staged

Secara lalai, -W dan --worktree akan memulihkan pepohon kerja daripada indeks, sama seperti jika tiada pilihan ditentukan (seperti git restore -- ./main.c ). Manakala -S dan --staged akan memulihkan kandungan indeks dari HEAD. Apabila melepasi kedua-duanya, indeks dan pokok berfungsi akan dipulihkan daripada HEAD.

Contohnya:

# Restoring the working tree from the index
$ git restore -- ./main.c
# Equivalent to
$ git restore --worktree -- ./main.c

# Restoring index content from HEAD
$ git restore --staged -- ./main.c

# Restoring the working tree and index from HEAD
$ git restore --staged --worktree ./main.c

Tunjukkan dengan graf:

Ditch Git Checkout: Use Git Switch and Git Restore Instead

Yang disebut di atas adalah lalai, jika kita ingin memulihkan dari komit yang berbeza, kita boleh menggunakan pilihan --source. Cth:

# Restore `./main.c` in the working tree with the last commit
$ git restore -s HEAD^ -- ./main.c
# Equivalent to
$ git restore --source=HEAD^ -- ./main.c

Satu lagi kes pemulihan git yang berguna mungkin memulihkan fail yang tidak dikendalikan. Cth:

# Incorrectly deleted files
$ rm -f ./main.c

# Quickly restore main.c from index
$ git restore ./main.c

Untuk pemulihan kelompok:

# Restore all C source files to match the version in the index
$ git restore '*.c'

# Restore all files in the current directory
$ git restore .

# Restore all working tree files with top pathspec magic
$ git restore :/

Kesimpulan

Ciri git checkout dipisahkan dengan jelas: suis git digunakan untuk menukar cawangan, manakala git restore digunakan untuk memulihkan fail pokok yang berfungsi. Ia memberikan semantik yang lebih eksplisit, selaras dengan falsafah UNIX.

Kedua-dua arahan telah dicadangkan pada tahun 2019, dan setakat ini, ia adalah percubaan. Mungkin ada perubahan, tetapi biasanya tidak banyak, jadi anda boleh menggunakannya sekarang, ia lebih mudah difahami dan kurang mengelirukan.

Jika anda mendapati ini membantu, sila pertimbangkan melanggan surat berita saya untuk lebih banyak artikel dan alatan berguna tentang pembangunan web. Terima kasih kerana membaca!

Atas ialah kandungan terperinci Ditch Git Checkout: Gunakan Git Switch dan Git Restore Sebaliknya. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn