La comparaison des versions de fichiers est l'une des taches les plus courantes lorsque vous travaillez avec Git, et git diff
est la commande incontournable pour repérer les changements entre les commits, les branches ou les états de travail. Que vous examiniez vos propres modifications avant de commettre ou de vérifier ce qui diffère entre deux branches, comprendre comment utiliser efficacement git diff
peut gagner du temps et prévenir les erreurs.
Voici comment utiliser git diff
pour comparer les versions de fichiers dans des scénarios pratiques.
1. Voir les changements dans le répertoire de travail
Si vous avez apporté des modifications à un fichier mais que vous ne les avez pas encore mis en scène, utilisez:
git diff
Cela montre des changements non mis en scène - les différences entre votre répertoire de travail et la zone de mise en scène. Il est utile pour examiner ce que vous avez changé avant d'exécuter git add
.
Par exemple, si vous avez modifié
index.js
mais que vous ne l'avez pas mis en scène,git diff
montrera des ajouts ligne par ligne (en vert) et des suppressions (en rouge).
Pour voir les modifications mise en scène (ce qui sera inclus dans le prochain engagement), utilisez:
git diff - cache
ou
git diff - staged
Cela compare la zone de mise en scène avec le dernier commit.
2. Comparez des fichiers spécifiques entre les commits
Pour voir comment un fichier particulier a changé entre deux commits:
git diff <commit1> <grissic2> - <nom de fichier>
Par exemple:
Git Diff Head ~ 3 Head - App.js
Cela montre des modifications apportées à app.js
d'il y a trois commits à la HEAD
actuelle.
Vous pouvez également utiliser les noms de branche:
Git Diff Caractéristique principale / auth - Config / Routes.rb
Cela compare routes.rb
entre les branches main
et feature/auth
.
3. Comparez les succursales ou les engagements
Pour voir tous les changements entre deux branches:
git diff main..Feature
ou simplement:
Git Diff Main Feature
Cela produit toutes les modifications de fichiers entre les pointes de main
et feature
. Il est utile avant de fusionner pour comprendre ce qui est introduit.
Remarque: la commande compte.
git diff AB
montre ce qui doit être ajouté à A pour obtenir B - c'est-à-dire des changements de A à B.
4. Options utiles pour une meilleure sortie
--color-words
: montre des changements au niveau des mots dans les lignes, pas seulement les diff de ligne entière.git diff - coulor-mots
--stat
: résume les modifications par fichier, montrant le nombre d'insertions / suppressions.git diff --stat Head ~ 5 tête
-p
ou pas d'indicateur : View de patch par défaut, affiche le contexte et les modifications réelles de code.--name-only
: répertorie uniquement les noms de fichiers qui diffèrent.Git Diff - Fonction principale uniquement
--summary
: ajoute des informations sur les fichiers nouveaux, supprimés ou renommés.
5. Comparez des gammes spécifiques (avancé)
Vous pouvez utiliser une syntaxe de révision spéciale:
-
HEAD~1
: un engagement avant la tête -
HEAD~5
: Cinq s'engage -
main@{yesterday}
: oùmain
a pointé hier (basé sur le réflog)
Exemple:
git diff Head ~ 2..head ~ 1
Montre les changements introduits dans le deuxième à la dernière validation.
Ou utilisez des balises:
git Diff v1.0.0 v1.1.0 - src /
Compare tous les fichiers dans src/
Entre deux versions.
L'utilisation git diff
vous aide intelligemment à attraper les bugs t?t, à comprendre les changements d'équipe et à assurer des commits propres. Vous n'avez pas besoin d'une interface graphique - la ligne de commande vous donne un contr?le précis et scriptable sur les comparaisons de version.
Fondamentalement, si quelque chose a changé, git diff
peut vous montrer exactement quoi - aucune conjecture nécessaire.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undress AI Tool
Images de déshabillage gratuites

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
échangez les visages dans n'importe quelle vidéo sans effort grace à notre outil d'échange de visage AI entièrement gratuit?!

Article chaud

Outils chauds

Bloc-notes++7.3.1
éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

PackFile est un mécanisme efficace utilisé par GIT pour package, compresser et transférer des objets de référentiel. Lorsque vous exécutez gitpush, gitfetch ou gitclone, ce que Git transmet réellement le packfile; 1. Il est initialement généré par des objets laches via des commandes GITGC ou GITREPACK et stocké dans le .git / objets / pack / répertoire; 2. Le PackFile contient non seulement des données d'objet, mais enregistre également la relation delta entre les objets et réalise une recherche rapide avec le fichier d'index (.IDX). 3. Cette conception réduit le volume de transmission et améliore l'efficacité de synchronisation; 4. Un grand nombre de petits packfiles peuvent affecter les performances et peuvent être utilisés via Gitgc ou Git

Pour afficher l'historique Git Commit, utilisez la commande gitlog. 1. L'utilisation de base est Gitlog, qui peut afficher le hachage de soumission, l'auteur, la date et les informations de soumission; 2. Utilisez Gitlog - Online pour obtenir une vue concise; 3. Filtre par l'auteur ou les informations de soumission via - Auteur et --Grep; 4. Ajouter -P pour afficher les modifications de code, - stat pour afficher les statistiques de changement; 5. Utilisez - GRAPH et - TOUT pour afficher l'historique de la branche, ou utiliser des outils de visualisation tels que Gitkraken et VScode.

Pour supprimer une branche GIT, assurez-vous d'abord qu'elle a été fusionnée ou aucune rétention n'est requise. Utilisez Gitbranch-D pour supprimer la branche fusionnée locale. Si vous devez forcer la suppression des branches non fusionnées, utilisez le paramètre -D. La suppression de branche à distance utilise la commande gitpushorigin-selebranch-name et peut synchroniser les référentiels locaux des autres via Gitfetch-prne. 1. Pour supprimer la branche locale, vous devez confirmer si elle a été fusionnée; 2. Pour supprimer la branche distante, vous devez utiliser le paramètre - Delete; 3. Après la suppression, vous devez vérifier si la branche est supprimée avec succès; 4. Communiquez avec l'équipe pour éviter de supprimer accidentellement des succursales partagées; 5. Nettoyez régulièrement les branches inutiles pour garder l'entrep?t propre.

Toswitchgitbranches, premierpdateTheLocalRepowithGitFetch, vérifiez lesBranches avec des dresses de terre, alors utilisegitcheckoutorgitswitchtochangebanches, mangeinguncommittesbycomitch, stashing, ordiscardingthem.wenswitchgitbranches, assureyourlocalalalm.wiswitchgitbranches, assureyourlocalalalalm.wiswitchgitbranches, assureyourloalalalalm.

Pour éliminer les modifications du répertoire de travail GIT et revenir à l'état du dernier engagement, 1. Pour les modifications des fichiers suivis, utilisez Gitcheckout-- ou gitcheckout--. Rejeter toutes les modifications; 2. Pour les nouveaux fichiers qui ne sont pas suivis, utilisez Gitclean-F pour supprimer les fichiers. Si le répertoire est inclus, utilisez Gitclean-FD. Avant l'exécution, utilisez GitClean-FD pour prévisualiser le contenu Supprimer; 3. Si vous devez réinitialiser toutes les modifications (y compris la zone de stockage temporaire et le répertoire de travail), utilisez Gitreet-Hard. Cette commande réinitialisera le répertoire de travail et la zone de stockage temporaire. Assurez-vous de fonctionner avec prudence. Ces méthodes peuvent être utilisées individuellement ou en combinaison pour atteindre le but de nettoyer le répertoire de travail.

Pour ajouter un sous-arbre à un référentiel GIT, ajoutez d'abord le référentiel distant et obtenez son historique, puis fusionnez-le dans un sous-répertoire à l'aide des commandes Gitmerge et Gitread. Les étapes sont les suivantes: 1. Utilisez la commande gitremoteadd-f pour ajouter un référentiel distant; 2. Exécutez Gitmerge-Sécursive-no-Commit pour obtenir du contenu de branche; 3. Utilisez gitread-tree - préfix = pour spécifier le répertoire pour fusionner le projet en tant que sous-arbre; 4. Soumettre les modifications pour compléter l'addition; 5. Lors de la mise à jour, gitfetch en premier et répétez la fusion et les étapes pour soumettre la mise à jour. Cette méthode maintient l'historique du projet externe complet et facile à entretenir.

Les crochets GIT sont utilisés pour exécuter automatiquement les scripts avant et après les commits, les poussées et autres opérations pour exécuter des taches. Les utilisations spécifiques incluent: 1. Exécutez des vérifications ou des tests de code avant la soumission; 2. Format d'informations de soumission forcée; 3. Envoyez des notifications après la poussée. Ils aident à unifier les spécifications de l'équipe et à réduire les étapes manuelles, telles que la prévention des soumissions lorsque les tests échouent. Les crochets GIT sont situés dans le répertoire .git / hooks / dans le référentiel et ne sont pas partagés par défaut. Ils doivent être copiés manuellement ou utiliser des outils tels que Husky pour la collaboration d'équipe. L'écriture d'un crochet de base nécessite de créer un fichier exécutable et de nommer l'événement correspondant, tel que pré-engager, et de rédiger des jugements logiques pour bloquer ou autoriser les opérations.

SoundStageafaFileiitTwittingChatcase, usegitizeadtordoremevome fromarningareAilact.toundact rungit reset.
