`

Git 进阶功能(转载)

git 
阅读更多

Git 进阶功能

【TIP】在我们的《Windows 下 Git 配置与使用指南》 中,有介绍大家使用 $ git go 命令。其实,这并非 Git 的原生命令,它是我们自定义的一个 alias(别名),由 $git add、$git commit、$git push 和 $git pull 四个命令组合而成。待熟悉之后,你可以直接使用这些原生命令,或者自定义更适合自己的 alias。

add

添加新文件到 Git 代码仓库的索引中

$ git add filename

mv

移动或重命名文件

$ git mv old-filename new-filename

rm

从工作目录和 Git 代码索引中删除文件

$ git rm filename

status

查看目前工作目录的代码状态,自上次提交以来的添加、修改和删除等

$ git status

diff

查看自上次提交以来,本地代码改动的具体情况

$ git diff

commit

提交修改的代码(只是提交到本地的代码库,不会推送到服务器)

$ git commit -am '修改说明'

如果觉得刚提交的“修改说明”写得不够好,可输入以下命令调整

$ git commit --amend

push

将自上次 push 以来的,本地历次 commit,推送到服务器

结合我们的实际,应该这样写:

$ git push origin master:your-id

其中,master 是本地的分支名;your-id 填你在服务器上的 id,服务器的版本库里会有以你的 id 为名称的分支。

pull

将别人推送到服务器的代码,拉到你的机器里

$ git pull

log

查看修改记录,含作者、时间、修改说明等

$ git log

show

显示具体的代码改动情况

显示最后一次 commit 修改的内容:
$ git show
显示指定 commit 修改的内容:

【TIP】git log 命令中,每条 commit 会有一长长的字符串,此即 commid id,取其前面五六位即可。

$ git show commit-id

branch

分支管理

列出所有分支(当前所在分支前会有“*”号):
$ git branch
新建分支:
$ git branch 新分支名
删除分支:
$ git branch -d 欲删除的分支名

【注意!】不要把 ‘-d’ 写成了 ‘-D’,危险!

  • -d:要求:被删除分支的所有修改,已经合并到当前分支;
  • -D:直接删除,未合并的代码,将被丢弃!

checkout

恢复某个已修改的文件(撤销未提交的修改):
$ git checkout file-name
切换到另外的分支,进行开发:
$ git checkout branch-name

【注意!】该命令可能伴随大量的文件增删/修改。Windows 下,改动已被占用的文件可能会被拒绝,导致版本库出现严重问题。如果确实要这样做,安全起见,最好先注销一次。

merge

合并指定分支到当前分支:

$ git merge branch-name

revert

还原已提交的修改(已经提交过的修改,可以反悔~)

还原最近一次提交的修改:
$ git revert HEAD
还原指定版本的修改:
$ git revert commit-id

stash

先将未提交的修改暂存起来,接着清除所有改动,使之与没修改时一样。

若你正在开发功能 A,又需立即去开发功能 B。A 的代码正改到一半,未认真整理,你不想立即提交。此时……请呼叫 stash ~。

它会使你所有未提交的修改瞬间不见了:
$ git stash
它会使刚刚不见了的修改,瞬间又回来了:
$ git stash pop

【TIP】以上命令皆有更多参数,另有一些 Git 命令我们此处没有介绍。但是,这已足令你使用 Git 时游刃有余,你会觉得,Git 简直是一件神器!:-)

【TIP】’$ git help’ 与 ‘$ git help 命令名’ 会在你需要的时候,无私地帮助你。:-)

附:git push 失败的解决办法

假设执行操作:

1. 修改代码
2. git commit
3. git push

此时 push 失败(错误提示:! [rejected] master -> master (non-fast-forward) )

解决办法:

$ git pull

若成功,则:

$ git push origin master:your-id

完事。

若失败(提示:CONFLICT (content): Merge conflict in 文件名),则:

冲突的文件会有类似下面的代码块:

<<<<HEAD
你修改的代码
============
其他人修改的代码
>>>>>commit id of others'

考虑你和他人对代码的修改,更新成合适的内容,并删除 <<<、===、>>> 3行标记符号,保存文件。

$ git commit -am "resolve conflict"
$ git push origin master:your-id

更详细的说明,可以阅读 $git push –help 该文档的 NOTE ABOUT FAST-FORWARDS 一节。

<script type="text/javascript"></script>

分享到:
评论

相关推荐

    25个 Git 进阶技巧.pdf

    25个 Git 进阶技巧 Git 是一个强大的版本控制系统,提供了很多实用的命令和技巧。本文将介绍 25 个 Git 进阶技巧,帮助开发者更好地掌握 Git。 1. 添加远端服务器 使用 `git remote add` 命令可以添加一个新的远...

    25个Git进阶技巧

    对常用的git命令做了简单而系统的说明。

    6.6: 版本控制 、 Git基础 、 Git进阶 、 RPM打包 、 总结和答疑.docx

    在Linux环境中,Git提供了高效、安全的版本管理功能。本文档主要介绍了Git的基础操作、HEAD指针操作、分支操作以及RPM包的制作。 首先,Git的基本操作包括安装、创建版本库、客户端克隆、本地修改以及提交。在Linux...

    Git进阶技巧:提升团队协作效率个人学习笔记.md

    本文介绍了Git的一些进阶使用技巧,包括分支管理、合并策略、钩子脚本等,旨在帮助读者提升团队协作中的代码管理效率,解决常见的问题和挑战。

    25个 Git 进阶技巧(翻译)

    本文总结了25个 Git 的进阶技巧,旨在帮助已经熟悉基础操作的用户进一步提升效率和理解Git的内在机制。 1. **配置个人信息**: 在安装Git后,首先要设置你的用户名和邮箱,这是每个提交都会附带的信息: ``` $ ...

    Git官方最新版下载 Git-2.18.0-64-bit 64位Windows版本

    Git-2.18.0-64-bit是Git官方发布的一个针对64位Windows系统的更新版本,旨在提供更稳定、高效和功能丰富的代码管理体验。 1. Git的基本概念: - 版本控制:Git的核心功能是版本控制,它记录了代码的每一次修改,...

    Git从入门到进阶,你想要的全在这里.rar

    这份名为"Git从入门到进阶,你想要的全在这里"的压缩包文件,显然是一份全面介绍Git的教程资料,旨在帮助用户从零基础开始,逐步掌握Git的核心功能和高级用法。 Git的核心理念是版本管理,它允许开发者跟踪代码的...

    Pro Git 2nd Edition

    git进阶 If you are a graphic or web designer and want to keep every version of an image or layout (which you would most certainly want to), a Version Control System &#40;VCS&#41; is a very wise thing ...

    Pro git.pdf (源自官方指定的 git学习、进阶、深入的500页说明书)

    从Git官方网站下载的文件,中文版git使用指南,超详细。

    git压缩包下载git下载

    在本篇中,我们将深入探讨Git的核心概念、功能以及如何下载和安装Git。 Git的核心概念: 1. 仓库(Repository):存储项目所有版本和历史信息的地方。 2. 分支(Branch):代表项目的不同开发线路,主分支通常命名...

    Git下载 64位 官方正式版 windows Git-2.31.1-64-bit.exe

    此外,学习如何处理分支(`git branch`、`git merge`、`git rebase`)以及解决合并冲突也是Git进阶技能的一部分。 总之,Git-2.31.1-64-bit.exe是Windows用户享用Git强大功能的可靠途径,无论是个人项目还是团队...

    Java进阶版本管理工具Git全套视频教程

    2.1.2 Git 3. Git 发展简史 4. Git 的安装 4.1 git 的下载 4.2 安装 5. Git 工作流程 5.1 Git 初始化 5.2 git 流程 5.2.1 流程图 5.2.2概念即详解 6.Git 的基本使用01-TortoiseGit 操作本地仓库 6.1 初始化仓库 6.2 ...

    git尚硅谷笔记.pdf

    - **多人协作**:在团队中使用Git时,可以通过分支隔离不同的功能开发,定期合并到主分支。 - **跨团队协作**:对于不在同一团队中的开发者,可以通过共享远程仓库实现协作。 #### 七、案例分析与实践 假设项目中...

    Git 原理详解及实用指南.zip

    3. **Git进阶操作** - 分支管理:`git branch` 列出所有分支,`git checkout -b &lt;new_branch&gt;` 创建并切换分支。 - 合并分支:`git merge &lt;branch&gt;` 将指定分支的更改合并到当前分支。 - HEAD、master与branch:...

    有关git的相关详细文档

    - **Git的特点**包括:高效快速、数据完整性高、支持非线性工作流(即分支)、易于学习且功能强大。 #### 二、Git安装与配置 ##### 2.1 Git安装 - **Windows平台下Git的安装**通常较为简单。下载Git安装包(例如:`...

    git电子教程汇总(5本权威电子书)

    "git_Magic_CN"这个名字暗示这可能是一本中文版的Git进阶教程,涵盖了Git的一些高级特性,如子模块、工作流策略、钩子脚本、rebasing等。这些内容对于团队协作和项目管理尤为重要,能帮助开发者实现更高效、更整洁的...

    git-2.35.1官方git软件包

    总之,Git-2.35.1作为官方发布的软件包,为Linux用户提供了最新的Git功能和优化,对于软件开发者和项目管理者来说,及时更新到这个版本有助于提升工作效率和代码管理的质量。在实际应用中,用户应当根据自身的需求和...

    Git-1.9.0 git

    Git-1.9.0是Git版本控制系统的一个重要版本,Git是一种分布式版本控制系统,由Linux创始人林纳斯·托瓦兹创建,旨在提高软件开发...通过深入学习和实践,开发者可以充分利用Git的强大功能,提升项目管理和协作的质量。

Global site tag (gtag.js) - Google Analytics