Esses três comandos têm finalidades completamente diferentes. Eles não são nem remotamente semelhantes.
git revert
Este comando cria uma nova confirmação que desfaz as alterações de uma confirmação anterior. Este comando adiciona novo histórico ao projeto (não modifica o histórico existente).
git checkout
Este comando faz check-out do conteúdo do repositório e o coloca em sua árvore de trabalho. Também pode ter outros efeitos, dependendo de como o comando foi chamado. Por exemplo, também pode alterar em qual filial você está trabalhando atualmente. Este comando não faz nenhuma alteração no histórico.
git reset
Este comando é um pouco mais complicado. Na verdade, ele faz algumas coisas diferentes, dependendo de como é invocado. Ele modifica o índice (a chamada "área de preparação"). Ou ele altera o que confirma um cabeçalho de ramificação atualmente apontando. Este comando pode alterar o histórico existente (alterando o commit que uma ramificação faz referência).
Usando estes comandos
Se uma confirmação foi feita em algum lugar na história do projeto, e você mais tarde decidir que a confirmação está errada e não deveria ter sido feita, então git revert
é a ferramenta para o trabalho. Isso desfará as alterações introduzidas pelo commit incorreto, registrando o "desfazer" no histórico.
Se você modificou um arquivo em sua árvore de trabalho, mas não confirmou a alteração, pode usar git checkout
para fazer check-out de uma cópia nova do repositório.
Se você fez um commit, mas não o compartilhou com mais ninguém e decide que não o deseja, poderá git reset
reescrever o histórico para que pareça que você nunca fez esse commit.
Estes são apenas alguns dos cenários de uso possíveis. Existem outros comandos que podem ser úteis em algumas situações, e os três comandos acima têm outros usos também.
git reset
egit checkout
podemos fazer exatamente a mesma coisa. Dizer que "não são nem remotamente parecidos" não é apenas um exagero: não é nem remotamente verdade. Esses dois comandos podem fazer muitas coisas diferentes, algumas das quais se sobrepõem completamente. Exemplo:git reset --hard
egit checkout -- .
fará exatamente a mesma coisa. E logicamente falando,git reset --hard <path>
egit checkout <path>
também deve fazer exatamente a mesma coisa - o git, no entanto, impede que você faça isso. Confundir esses dois comandos é MUITO fácil.git reset --hard <path>
que podegit checkout <path>
exatamente porque os dois comandos fazem algo completamente diferente.git reset
diz ao Git para mover HEAD para um commit diferente.git checkout
por outro lado, não pede ao Git que faça nada com o HEAD. Ele deixa o HEAD sozinho e apenas faz check-out de um arquivo. Sim, você pode criá-los de uma maneira que eles tenham efeitos semelhantes. Mas o que eles realmente fazem é totalmente diferente.Digamos que você tenha confirmados:
git revert B
, criará uma confirmação que desfaz alteraçõesB
.git revert A
, criará uma confirmação que desfaz alteraçõesA
, mas não toca nas alteraçõesB
Observe que se as alterações em
B
dependem de alteraçõesA
, a reversão deA
não é possível.git reset --soft A
, alterará o histórico e o repositório de confirmação; o diretório de teste e o trabalho ainda estarão no estado deC
.git reset --mixed A
, alterará o histórico, o repositório e a preparação da consolidação; O diretório de trabalho ainda estará no estado deC
.git reset --hard A
, alterará o histórico de consolidação, repositório, preparo e diretório de trabalho; você voltará ao estadoA
completamente.fonte
git revert
é usado para desfazer uma confirmação anterior. No git, você não pode alterar ou apagar um commit anterior. (Na verdade, você pode, mas pode causar problemas.) Portanto, em vez de editar o commit anterior, o revert introduz um novo commit que reverte o anterior.git reset
é usado para desfazer alterações em seu diretório de trabalho que ainda não foram confirmadas.git checkout
é usado para copiar um arquivo de outra confirmação para sua árvore de trabalho atual. Não confirma automaticamente o arquivo.fonte
git reset --soft
redefine apenas o HEAD,git reset --hard
redefine o HEAD e seu diretório de trabalho.git checkout
modifica sua árvore de trabalho,git reset
modifica em qual referência o ramo em que você está aponta,git revert
adiciona uma confirmação desfazendo alterações.fonte
git reset
não modifica apenas a confirmação apontada por uma ramificação , também é usada para desestabilizar arquivos do índice e pode modificar a cópia de trabalho comgit reset --mixed
(o padrão).Redefinir - no nível de confirmação, a redefinição é uma maneira de mover a ponta de uma ramificação para uma confirmação diferente. Isso pode ser usado para remover confirmações da ramificação atual.
Reverter - reverter desfaz um commit criando um novo commit. Essa é uma maneira segura de desfazer alterações, pois não há chance de reescrever o histórico de consolidação. Compare isso com o git reset, que altera o histórico de confirmação existente. Por esse motivo, o git revert deve ser usado para desfazer alterações em uma ramificação pública e o git reset deve ser reservado para desfazer alterações em uma ramificação privada.
Você pode dar uma olhada neste link - Redefinir, Checkout e Reverter
fonte
Se você quebrou a árvore, mas não confirmou o código, pode usá-lo
git reset
e, se quiser apenas restaurar um arquivo, pode usá-logit checkout
.Se você quebrou a árvore e confirmou o código, pode usar
git revert HEAD
.http://book.git-scm.com/4_undoing_in_git_-_reset,_checkout_and_revert.html
fonte