有用的git建议
这篇文章的目的是给经常使用git管理项目提供一个有益的提醒。如果你是git新手,可以先阅读文后的引用部分,然后在回头阅读此篇文章。在介绍git命令之前,你可以先看看来自 on-my-zsh 提供的别名。
基本命令
git config --global user.name "Your Name"git config --global user.email "youremail@example.com"git config --global core.editor <your favorite editor here>- Ex:
git config --global core.editor vim
- Ex:
git init:初始化一个repo。
Commit 结构
git status(gst):查看 repo 状态- 工作区:
- .git 目录
- 暂存区
- 工作目录

git add <filename>(ga):添加一个文件到暂存区git add .(gaa):添加所有文件到暂存区git add *.js:添加所有后缀为js的文件到暂存区git rm --cached <file>:从暂存区删除一个新文件git commit -m "My first commit"(gcmsg):创建一次带 message 的提交git commit -v -a(gca):-v是 verbose 的缩写,会在底部显示差异信息和更多有意义的信息-a类似于git add .,会添加所有被修改和删除的文件,但会忽略新创建的文件
git help <command>:查看对应命令的帮助手册git log(glg,glgg,glo,glog):查看项目的提交历史
暂存区管理
git reset HEAD <filename>(grh):从暂存区删除一个被修改的文件git reset HEAD(grh):从暂存区删除所有被修改的文件git checkout <filename>(gco):从暂存区删除一个被修改的文件,并撤销文件的更改git commit -m "My first commit" --amend:添加文件/更改在暂存区的最后一次提交git commit -v -a --amend(gca!):添加文件/更改在暂存区的最后一次提交.gitignore:告诉git,哪些文件不被加入版本跟踪- 可以使用
git add <filename> -f命令添加一个不被版本跟踪的文件
- 可以使用
git diff <filename>(gd):查看基于当前文件的最后一次提交的更改差异git diff(gd):查看基于所有文件的最后一次提交的更改差异git reset HEAD~2 --soft:从项目提交历史中删除最近两次提交,但不丢弃文件的更改git reset HEAD~2 --hard:从项目提交历史中删除最近两次提交,但会丢弃文件的更改和在(最后两次)提交中创建的新文件git reset <commit> --soft --hard:--soft:将所有被更改的文件回溯到“待提交”状态--hard:commit之后,对被git追踪的文件的任何更改都被丢弃
git reflog:显示包括被撤销
在内的所有提交git merge <commit hash>:重新提交(restore the commit)git clean -f:删除工作目录中不被git进行版本追踪的文件
Stashed & Branches
Stash
git stash(gsta):将所有暂存区的文件移动到“储藏区”,类似于另一种类型的工作区git stash list:查看储藏队列(Stash lists)git stash apply:将最近一次储藏恢复到暂存区(可以用类似git stash apply stash@{num}(num从0开始计数) 的命令来使用在队列中的任意一个储藏(stashes))git stash clear:清空储藏队列git stash save "name of the stash":为储藏设置命名git stash pop(gstp):将最近一次储藏恢复到暂存区并从储藏队列删除此储藏git stash drop(gstd):从储藏队列删除最近一次储藏(stash@{0})(git stash drop stash@{num}从储藏队列删除指定储藏)
Branch
git checkout -b dev(gco):创建 dev 分支并从当前分支切换到 dev 分支git branch(gb):查看所有分支git checkout master(gcm):切换到主分支git merge <branch>(gm):合并分支git rebase master:先将 master 上的更改合并到当前分支,再添加当前分支的更改。如果有冲突,解决冲突后加--continue参数继续合并git branch -d <branch>: 删除分支,-D则强制删除分支git merge <branch> --squash:将多次提交合并成一个,其流程如下:
# Go to the `master` branch
git checkout master
# Create a temp branch
git checkout -b temp
# Merge the feature/x branch into the temp using --squash
git merge feature/x --squash
# See the new modifications/files in the Staging Area
git status
# Create the unified commit
git commit -m "Add feature/x"
# Delete the feature/x branch
git branch -D feature/x
- rebase 和 merge 的区别:
- rebase:
- 提交历史(的展示)是线性的
- 缺点:会删除最近一个 commit,然后创建一次新的 commit
- 如果已提交到远程,不要使用 rebase
- merge:
- 提交历史(的展示)是分叉的
- 对于两个分支的合并,会创建一个次新的 commit
- rebase:
远程仓库管理
git remote add <name> <url>:添加一个将被追踪的远程仓库git remote rm <name>:移除一个远程仓库git push <remote> <remote-branch>(gp,ggp):将当前分支的本地 commit 推送到远程仓库git fetch <remote> <remote-branch>:拉取远程仓库的最新 commit 到当前(本地)分支(<remote>/<branch>),不会合并git pull <remote> <remote-branch>(gl,ggl):拉取远程仓库的最新 commit 到当前(本地)分支,并自动 mergegit pull --rebase(gup):以 rebase 的方式进行合并,而不是 merge
其它有用的命令
git tag <name>:创建一个 tag(如:v1.3)git push --tags:将本地 tags 推送到远程仓库git push <tag>:推送指定的本地 tag 到远程
有用的git建议的更多相关文章
- 你不一定知道的几个很有用的 Git 命令
这里给大家分享一些很有用的 Git 命令,其中很多用法你可能都不知道,无论你是工作在团队环境中或在您的个人项目中,这些命令将对你帮助很大,让你可以更加高效的进行项目开发,更轻松愉快的工作和生活. 您可 ...
- 不常用但很有用的git show 和 git blame
团队使用git 合作时,可能遇见想要查看一段比较难以阅读代码, 此时可能需要联系最新的修改者是哪位,这时候最有用的最快捷的方法就是git blame 啦, 这个指令的output是一个文件的各个区域段 ...
- 有用的git片段
世界上知识那么多,又岂是人力所能穷尽,于是术业有专攻.对于git,有用的命令片段其实非常少,而命令却是非常多.于是,掌握git常见的用法就足够了.不要在语句级别上记忆git命令,在代码片段级别上记忆g ...
- git 建议使用
1 登录github官网首页 创建一个项目 2 本地克隆下载git项目 git clone https://github.com/wangguoxingduanxuejing/branch-pract ...
- 有用的git命令
1. git log -p // 查看log的详细信息 2. git reset HEAD xxxx // 将文件从stage状态拉出来 3. git checkout -- xxxx // 将修改的 ...
- 一些有用的git命令清单
以下是一些我常用的git命令清单 如果以下的命令不清晰细节,请看git的文档. 设置个人信息 git config --global user.name "John Doe" gi ...
- 8 个不常见但很有用的 Git 命令
1. 拉取远程代码并且覆盖本地更改 2. 列出远程和本地所有分支 3. 强制更新远程分支 4. 回滚一个 merge 5. 修改之前的提交记录或者很久前提交的记录 6. 使用多个远程代码库,并且使用多 ...
- 超级有用的git reset --hard和git revert命令
很多时候,git新手容易误操作,比如,在levelIISZ-1.4.dev分支下,运行了git pull idc cpp-1.0的结果,这样做麻烦很大,经常导致maven项目格式不正确,这个时候,可以 ...
- 日常使用 Git 的 19 个建议[转]
我使用Git已经有4年之久,在这里想分享一些实用的小技巧,希望能对大家有所帮助. 如果你对git一无所知,那么我建议先去读一下Git 常用命令速查.本篇文章主要适合有一定 git 使用基础的人群. 目 ...
随机推荐
- SQL Server 列存储索引强化
SQL Server 列存储索引强化 SQL Server 列存储索引强化 1. 概述 2.背景 2.1 索引存储 2.2 缓存和I/O 2.3 Batch处理方式 3 聚集索引 3.1 提高索引创建 ...
- 解决问题:The context cannot be used while the model is being created
使用Entity Framework (v6.1.3)突然遇到这个问题了,之前一直好好的,怎么破? 此处省略了多次在“好”与“坏"的项目中试验的过程(苦啊),直接给出答案.答案是:没有按Db ...
- sublime3 集成angularJs插件
sublime是web开发中一款轻量级高效编辑器,十分适合前端开发(安装sublime是需要注册的,请支持正版) 1.安装sublime3(http://www.sublimetext.com/3) ...
- MySQL插入语句解析
1.INSERT INTO 最常用简单的插入语句,可以有以下两种用法 1> INSERT INTO tb_user(id, name, age) VALUES (100022, 'Tom', ...
- 网络抓包工具-Wireshark学习资料
wireshark一个非常牛逼的网络抓包工具.转载一系列博文 一站式学习Wireshark(一):Wireshark基本用法 一站式学习Wireshark(二):应用Wireshark观察基本网络协议 ...
- Google的Java常用类库 Guava资料
java的人应该都知道Apache commons的java常用类库吧,这个Guava和commons一样,封装出一套比jdk本身提供的常用类库强大.既然有了这个这么强大的类库,我们就没必要重复造轮子 ...
- [mysql]三种方法为root账户指定密码
前言:前段时间把mysql安装后一直没管它,当时就在奇怪为什么mysql登陆不要密码,原来一直用的超用户账户登陆的(简称超级用户) 其实只怪自己太无知,之前一直用的phpbydamin进行的数据库的可 ...
- 第一个JAVA应用
1.1创建源文件 1.1.1Java源文件结构 Java应用由一个或多个扩展名为“.Java”的文件构成,这些文件被成为源文件.从编译角度,则被称为编译单元(Compilation Unit). 如果 ...
- UVALive - 3942 Remember the Word[Trie DP]
UVALive - 3942 Remember the Word Neal is very curious about combinatorial problems, and now here com ...
- 第16章 List集合的总结和遍历
第16章 List集合的总结和遍历 1.重构设计 根据Vector类,ArrayList类,和LinkedList类所具有的存储特点以及拥有的方法入手,发现共性往上抽取. 共同特点: 1.允许元素重复 ...