10篇 Git命令复习

Git是一个分布式版本控制系统,用于跟踪计算机文件的变化并协调多个用户之间的工作。以下是一些基本的Git命令,这些命令对于开始使用Git进行版本控制和协作是非常有帮助的:

1. `git init`: 初始化一个新的Git仓库。这个命令会在当前目录下创建一个名为`.git`的隐藏文件夹,用于存储版本控制的相关信息。

2. `git clone [repository-url]`: 克隆一个远程仓库到本地。这个命令会创建一个远程仓库的完整副本,并在本地创建一个新的目录。

3. `git status`: 查看当前工作目录的状态。这个命令会显示当前目录中的文件,以及它们相对于最后一次提交的状态(已修改、未跟踪等)。

4. `git add [file]`: 将文件添加到暂存区。这个命令用于将修改过的文件标记为下一次提交的一部分。

5. `git commit -m "message"`: 提交暂存区中的更改到仓库。`-m`选项后面跟着的是提交信息,用于描述这次提交的内容。

6. `git diff`: 显示工作目录和最后一次提交之间的差异。这个命令可以帮助你查看哪些更改还没有被暂存。

7. `git log`: 显示提交历史记录。这个命令会列出所有的提交,包括提交者、提交日期和提交信息。

8. `git remote add [remote-name] [url]`: 添加一个新的远程仓库。这个命令允许你指定一个远程仓库的URL,并给它一个名称,以便后续的推送和拉取操作。

9. `git push [remote-name] [branch-name]`: 将本地分支的更改推送到远程仓库。这个命令会将你的本地提交上传到远程仓库的指定分支。

10. `git pull [remote-name] [branch-name]`: 从远程仓库拉取更改到本地分支。这个命令会将远程分支的最新更改合并到你当前的本地分支。

这些命令是Git使用中最基础且最常用的一部分,掌握它们可以帮助你更有效地使用Git进行版本控制和协作开发。随着你对Git的进一步学习,你会发现还有更多的命令和选项可以帮助你更精细地管理你的代码和项目。

11. `git branch`: 列出、创建或删除分支。没有参数时,这个命令会显示当前仓库中所有的分支,以及你当前所在的分支。

12. `git checkout [branch-name]`: 切换到指定的分支,或者恢复工作目录中的文件。使用分支名称作为参数时,它会切换到该分支;如果使用文件路径,它会用暂存区或最后一次提交的版本覆盖工作目录中的文件。

13. `git merge [branch]`: 合并一个分支到当前分支。这个命令会将指定分支的更改合并到你当前所在的分支中。

14. `git branch -d [branch-name]`: 删除一个分支。这个命令会删除指定的分支,但是只有在该分支已经被合并到当前分支时才能成功。

15. `git fetch [remote]`: 从远程仓库下载所有的更改,但不自动合并到你的工作目录中。这个命令是安全地合并更改之前的一个步骤。

16. `git rebase [branch]`: 将当前分支的更改重新应用到指定分支之上。这个命令用于保持提交历史的线性,通过将一系列提交移到另一个分支的顶部。

17. `git reset [mode] [commit]`: 重置当前分支到指定的状态。`mode`可以是`--soft`、`--mixed`(默认)或`--hard`,分别对应不同的回退级别。

18. `git log --graph --oneline`: 以图形化的方式显示提交历史。这个命令提供了一个简洁的视觉表示,帮助你理解分支和合并的历史。

19. `git diff [commit1] [commit2]`: 比较两个提交之间的差异。这个命令显示了在两个指定提交之间文件的具体更改。

20. `git stash`: 临时保存工作目录中的更改。这个命令允许你将未提交的更改保存起来,以便你可以在一个干净的工作目录中切换分支或执行其他操作。

这些命令覆盖了Git的一些高级功能,包括分支管理、合并、重置和比较等。通过熟练使用这些命令,你将能够更加灵活和高效地处理复杂的版本控制任务。随着你对Git的进一步了解,你可能会接触到更多的命令和技巧,这将有助于你更好地管理你的代码库。

继续探索Git的更多高级命令和功能,这些命令可以帮助你更精细地控制版本历史和工作流程:

21. `git add -p`: 交互式地添加文件到暂存区。这个命令允许你逐个文件或逐个修改地进行添加,而不是一次性添加所有更改。

22. `git commit --amend`: 修改最近一次提交的信息。如果你忘记添加一些更改到上一次提交,或者想要更正提交信息,这个命令非常有用。

23. `git log -p`: 显示每次提交的差异。这个命令可以帮助你理解每次提交具体做了哪些更改。

24. `git blame [file]`: 显示文件中每一行的最后提交者。这对于追踪代码更改的历史和调试非常有用。

25. `git bisect`: 通过二分查找的方式定位引入错误或问题的提交。这个命令可以显著加快问题定位的过程。

26. `git cherry-pick [commit-hash]`: 将单个提交从一个分支应用到另一个分支。这个命令在需要将特定更改移植到不同分支时非常有用。

27. `git revert [commit-hash]`: 创建一个新的提交,撤销指定提交所做的更改。这个命令是处理错误提交的安全方式。

28. `git tag [tag-name]`: 创建一个标签,用于标记特定的提交。标签通常用于标记发布版本。

29. `git describe --tags`: 显示当前分支的最新标签信息。这个命令可以帮助你了解当前分支与已发布版本的关系。

30. `git clean`: 清理未跟踪的文件。这个命令会删除工作目录中的未跟踪文件和目录,但不会删除`.git`目录下的文件。

31. `git config --global [option]`: 设置全局Git配置。这个命令允许你配置全局的Git选项,如用户名、邮箱等。

32. `git ls-remote [remote]`: 列出远程仓库的所有引用。这个命令可以帮助你了解远程仓库的结构和分支。

33. `git remote show [remote-name]`: 显示远程仓库的详细信息。这个命令提供了关于远程仓库的详细信息,包括URL、跟踪的分支和本地分支与远程分支的对应关系。

34. `git submodule`: 管理Git仓库中的子模块。这个命令允许你初始化、更新和同步项目中的子模块。

35. `git gc`: 清理优化本地仓库。这个命令会删除不必要的文件和优化本地仓库,以提高性能和节省空间。

通过掌握这些Git命令,你将能够更有效地管理复杂的版本控制任务,提高工作效率,并保持代码库的整洁和有序。这些命令不仅适用于日常的开发工作,也适用于处理紧急情况和维护长期项目。随着你对Git的深入使用,你会发现更多有用的命令和技巧,不断提升你的版本控制能力。

继续探索Git的高级功能和命令,这些命令可以帮助你更高效地处理复杂的版本控制任务:

36. `git config --unset [option]`: 删除或重置Git配置选项。这个命令可以用来移除之前设置的配置,无论是局部的还是全局的。

37. `git mv [source] [destination]`: 移动或重命名文件或目录。这个命令不仅可以在文件系统中移动文件,还会相应地更新Git的索引。

38. `git rm --cached [file]`: 从索引中删除文件,但不删除工作目录中的文件。这个命令用于当你想从版本控制中移除文件,但还想保留在本地工作目录中的副本时。

39. `git reset HEAD [file]`: 将文件恢复到最后一次提交的状态。这个命令用于取消工作目录中的更改,将文件恢复到HEAD(最近的提交)状态。

40. `git log -p [file]`: 显示指定文件的提交历史和每次提交的差异。这个命令可以帮助你追踪文件的变更历史。

41. `git log --since="2024-01-01"`: 显示指定日期之后的提交。这个命令可以根据时间筛选提交历史。

42. `git log --grep="pattern"`: 显示包含特定文本的提交信息。这个命令允许你根据提交信息中的模式或关键词搜索提交。

43. `git log --pretty=format:"%h - %an, %ar : %s"`: 使用自定义格式显示提交历史。这个命令让你可以定制输出格式,以显示你关心的信息。

44. `git fetch [remote] [branch]`: 从远程仓库获取特定分支的最新更改。这个命令允许你选择性地获取某个分支的更新,而不是整个仓库的所有分支。

45. `git pull --rebase [remote] [branch]`: 使用rebase方式从远程仓库拉取更改。这个命令会在拉取更新时尝试rebase,以保持提交历史的线性。

46. `git push --force [remote] [branch]`: 强制推送到远程仓库。这个命令用于覆盖远程仓库的历史,应谨慎使用,因为它可能会影响其他协作者的工作。

47. `git log --graph --all`: 显示所有分支的提交历史和分支合并情况。这个命令提供了一个全面的视图,帮助你理解整个代码库的历史。

48. `git stash list`: 列出所有的储藏列表。这个命令显示了所有被储藏起来的工作,你可以使用它们来恢复之前的工作状态。

49. `git stash apply [stash@{n}]`: 应用特定的储藏到当前工作目录。这个命令允许你选择性地恢复之前储藏的工作,而不是应用所有的储藏。

50. `git reflog`: 显示HEAD引用日志。这个命令记录了HEAD指针的变化历史,包括提交、分支切换、cherry-pick等操作,甚至在某些情况下可以帮助你恢复丢失的提交。

通过熟练运用这些Git命令,你将能够更加灵活地处理各种版本控制场景,无论是日常的开发工作还是复杂的协作项目。这些命令不仅可以帮助你维护代码库的整洁和有序,还可以在出现问题时提供强大的工具来追踪和修复问题。随着你对Git的进一步学习和实践,你将不断提升你的版本控制技能,更好地服务于你的开发工作。

 

  • 16
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值