热门标签 | HotTags
当前位置:  开发笔记 > Android > 正文

Git常用命令整理

本文主要介绍了Git命令,这里对Git常用命令进行了整理,在开发项目过程中足够用了,有需要的小伙伴可以参考下

前言

  这里就不介绍 git 了,表一看到命令行就怕怕,常用的命令也就这些,基本满足 99% 以上的项目需求,非常实用。

正文

  一、常用 git 命令

    1.1  git clone []

      从远程库 clone 代码到本地,directory 用于指定一个新目录名

    1.2  git status

      检查本地状态,可以查看当前所在分支、新增或被修改的文件

    1.3  git checkout

      还原某文件所作的修改,也可以 "git checkout ." 还原所有修改

    1.4  git add

      添加文件到缓存,并追踪新的文件。也可以 "git add ." 添加所有文件到缓存

    1.5  git commit -m "commit message"

      提交代码到本地代码库,非常推荐做完一个小功能就 commit 一次,多次 commit 替代一次大 commit ,也便于后续代码合并和 review 。

    1.6  git push

      同步本地库代码到远程库。(push 失败后面会专门提到代码合并)

    1.7  git branch

      列出可用分支,git branch -a 列出本地和远程库所有分支

    1.8  git checkout

      切换分支

    1.9  git log [-]

      查看本地 commit 记录,number 可用限制 log 显示条数

    1.10  git diff []

      比较当前文件和暂存区文件差异

    1.11  git pull

      从远程库提取更新代码到本地

  二、代码撤销

    2.1  撤销本地未 add、未 commit 的代码

      git checkout 撤销单个文件,或者 "git checkout ." 撤销本地所有修改。

    2.2  撤销本地已经add、但未commit的代码

      git reset 撤销单个文件,git reset 撤销所有的

    2.3  撤销本地已经commit、但未push的代码

      git reset --hard HEAD~1 撤销最后一次 commit 并回退代码到上次 commit 的代码,注意代码就都丢弃了。(不加 --hard 可以只撤销 commit,不回退代码)

    2.4  撤销已经 commit 并且已经 push 的代码

      git revert

    2.5  修改已经commit的注释内容

      git commit --amend,一般会用 vim 打开,修改完 :wq 退出即可。

  三、同分支代码合并

    适用场景:git pull 失败或者已知远程库有更新的情况下,注意本地先 commit,然后再 rebase 操作。

    3.1  git pull --rebase

      从远程库提取更新代码到本地,并尝试合并代码。与 merge 不同,不会产生新的 commit 记录,合并代码的时候需要非常小心,不要把别的小伙伴的代码弄丢了!

    3.2  git add

      遇到冲突解决冲突,解决完成以后git add

    3.3  git rebase --continue

      所有冲突都解决完并 add 完以后继续 rebase,不要 commit,可能需要多次 continue 和 add 操作,直至全部合并完。

    3.4  git push

      将本地代码库代码同步到远程库。

  四、不同分支代码合并

    适用场景:把代码从 develop 分支(开发)合并到 master 分支(生产)

    4.1  git cherry-pick

      把另一个分支的 commit 修改应用到当前分支。commit id支持跨分支、短 commit id(前 8 位,例如 247d27c6),当然也支持用于同一分支。

    4.2  git add

      遇到冲突解决冲突,解决完成以后git add

    4.3  git rebase --continue

      所有冲突都解决完并 add 完以后继续 rebase,不要 commit ,可能需要多次 continue 和 add 操作,直至全部合并完。

    4.4  git push

      将本地代码库代码同步到远程库。

  五、代码暂存

    适用场景:功能未完成又不想 commit,但是又急需还原代码到上次 commit(例如紧急bug修复)

    5.1  git stash

      暂存未 commit 的代码并还原所有修改

    5.2  git stash pop

      还原最后一次 stash 的代码

  六、其他

    6.1  Android

      Android Studio 自带的版本管理非常好用,非常方便切换分支、对比修改、合并提交代码。

    6.2  iOS

      可以用 XCode 自带的版本管理检测对比,commit 到本地,然后通过命令行来合并。

      也有不少同学用 SourceTree

     6.3  Git 官方中文版

      https://git-scm.com/book/zh

以上就是对Git 常用命令的整理有需要的朋友可以参考下。


推荐阅读
  • 2023年1月28日网络安全热点
    涵盖最新的网络安全动态,包括OpenSSH和WordPress的安全更新、VirtualBox提权漏洞、以及谷歌推出的新证书验证机制等内容。 ... [详细]
  • 使用IntelliJ IDEA高效开发与运行Shell脚本
    本文介绍了如何利用IntelliJ IDEA中的BashSupport插件来增强Shell脚本的开发体验,包括插件的安装、配置以及脚本的运行方法。 ... [详细]
  • Docker基础入门与环境配置指南
    本文介绍了Docker——一款用Go语言编写的开源应用程序容器引擎。通过Docker,用户能够将应用及其依赖打包进容器内,实现高效、轻量级的虚拟化。容器之间采用沙箱机制,确保彼此隔离且资源消耗低。 ... [详细]
  • 默认情况下,Git 使用 Nano 编辑器进行提交信息的编辑,但如果您更喜欢使用 Vim,可以通过简单的配置更改来实现这一变化。本文将指导您如何通过修改全局配置文件来设置 Vim 作为默认的 Git 提交编辑器。 ... [详细]
  • iOS 小组件开发指南
    本文详细介绍了iOS小部件(Widget)的开发流程,从环境搭建、证书配置到业务逻辑实现,提供了一系列实用的技术指导与代码示例。 ... [详细]
  • 本文将详细介绍如何配置并整合MVP架构、Retrofit网络请求库、Dagger2依赖注入框架以及RxAndroid响应式编程库,构建高效、模块化的Android应用。 ... [详细]
  • 使用 ModelAttribute 实现页面数据自动填充
    本文介绍了如何利用 Spring MVC 中的 ModelAttribute 注解,在页面跳转后自动填充表单数据。主要探讨了两种实现方法及其背后的原理。 ... [详细]
  • 深入理解iOS中的链式编程:以Masonry为例
    本文通过介绍Masonry这一轻量级布局框架,探讨链式编程在iOS开发中的应用。Masonry不仅简化了Auto Layout的使用,还提高了代码的可读性和维护性。 ... [详细]
  • Docker安全策略与管理
    本文探讨了Docker的安全挑战、核心安全特性及其管理策略,旨在帮助读者深入理解Docker安全机制,并提供实用的安全管理建议。 ... [详细]
  • 为帮助编程爱好者更好地掌握Python和Go语言的核心技能,我们特别提供两本精选图书的免费赠阅机会。《易懂的Python算法指南》适合所有希望提高算法理解能力的读者,《Go语言编程从入门到精通》则面向对Go语言感兴趣的初学者及有一定基础的开发者。 ... [详细]
  • 本文介绍了一个基本的同步Socket程序,演示了如何实现客户端与服务器之间的简单消息传递。此外,文章还概述了Socket的基本工作流程,并计划在未来探讨同步与异步Socket的区别。 ... [详细]
  • ED Tree HDU4812 点分治+逆元
    这道题非常巧妙!!!我们进行点分治的时候,算出当前子节点的所有子树中的节点,到当前节点节点的儿子节点的距离,如下图意思就是当前节点的红色节点,我们要求出红色节点的儿子节点绿色节点, ... [详细]
  • 深入解析Nacos服务自动注册机制
    本文将探讨Nacos服务自动注册的具体实现方法,特别是如何通过Spring事件机制完成服务注册。通过对Nacos源码的详细分析,帮助读者理解其背后的原理。 ... [详细]
  • 浅谈Android五大布局——LinearLayout、FrameLayout和AbsoulteLa
    为什么80%的码农都做不了架构师?Android的界面是有布局和组件协同完成的,布局好比是建筑里的框架,而组件则相当于建筑里的砖瓦。 ... [详细]
  • 本文档提供了在Windows 10操作系统中安装Python 3及Scrapy框架的完整指南,包括必要的依赖库如wheel、lxml、pyOpenSSL、Twisted和pywin32的安装方法。 ... [详细]
author-avatar
mobiledu2502906183
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有