10 Advanced git commend
来源:互联网 发布:游族网络大侠工作室 编辑:程序博客网 时间:2024/05/19 01:12
1. 输出最后一次提交的改变
这个命令,我经常使用它 来发送其他没有使用git的人来检查或者集成所修改的。它会输出最近提交的修改内容到一个zip文件中。
git archive -o ../updated.zip HEAD $(git
diff
--name-only HEAD^)
2. 输出两个提交间的改变
类似的,如果你需要输出某两个提交间的改变时,你可以使用这个。
1
git archive -o ../latest.zip NEW_COMMIT_ID_HERE $(git
diff
--name-only OLD_COMMIT_ID_HERE NEW_COMMIT_ID_HERE)
3. 克隆 指定的远程分支
如果你渴望只克隆远程仓库的一个指定分支,而不是整个仓库分支,这对你帮助很大。
1
git init
2
git remote add -t BRANCH_NAME_HERE -f origin REMOTE_REPO_URL_PATH_HERE
3
git checkout BRANCH_NAME_HERE
4. 应用 从不相关的本地仓库来的补丁
如果你需要其它一些不相关的本地仓库作为你现在仓库的补丁,这里就是通往那里的捷径。
1
git --git-
dir
=PATH_TO_OTHER_REPOSITORY_HERE/.git
format
-patch -k -1 --stdout COMMIT_HASH_ID_HERE| git am -3 -k
5. 检测 你的分支的改变是否为其它分支的一部分
cherry命令让我们检测你的分支的改变是否出现在其它一些分支中。它通过+或者-符号来显示从当前分支与所给的分支之间的改变:是否合并了(merged)。.+ 指示没有出现在所给分支中,反之,- 就表示出现在了所给的分支中了。这里就是如何去检测:
1
git cherry -
v
OTHER_BRANCH_NAME_HERE
2
#例如: 检测master分支
3
git cherry -
v
master
6.开始一个无历史的新分支
有时,你需要开始一个新分支,但是又不想把很长很长的历史记录带进来,例如,你想在公众区域(开源)放置你的代码,但是又不想别人知道它的历史记录。
1
git checkout --orphan NEW_BRANCH_NAME_HERE
7. 无切换分支的从其它分支Checkout文件
不想切换分支,但是又想从其它分支中获得你需要的文件:
1
git checkout BRANCH_NAME_HERE -- PATH_TO_FILE_IN_BRANCH_HERE
8.忽略已追踪文件的变动
如果您正在一个团队中工作,而且大家都在同一条branch上面工作,那么您很有可能会经常用到fetch和merge。但是有时候这样会重置您的环境配置文件,如此的话,您就得在每次merge后修改它。使用这一命令,您就能要求git忽视指定文件的变动。这样,下回你再merge的话,这个文件就不会被修改了。
1
git update-index --assume-unchanged PATH_TO_FILE_HERE
9.检查提交的变动是否是release的一部分
name-rev命令能告诉您一个commit相对于最近一次release的位置。使用这条命令,您就可以检查您所做出的改动是否是release的一部分了。
1
git name-rev --name-only COMMIT_HASH_HERE
10.使用rebase推送而非merge
如果您正在团队中工作并且整个团队都在同一条branch上面工作,那么您就得经常地进行fetch/merge或者pull。Git中,分支的合并以所提交的merge来记录,以此表明一条feature分支何时与主分支合并。但是在多团队成员共同工作于一条branch的情形中,常规的merge会导致log中出现多条消息,从而产生混淆。因此,您可以在pull的时候使用rebase,以此来减少无用的merge消息,从而保持历史记录的清晰。
1
git pull --rebase
您也可以将某条branch配置为总是使用rebase推送:
1
git config branch.BRANCH_NAME_HERE.rebase
true
- 10 Advanced git commend
- 10 Useful Advanced Git Commands
- NET commend
- Commend word
- svn commend
- mysql commend
- Ant commend
- android commend build.xml
- WPF Commend 命令
- 10 Advanced Bash Scripting
- 设计模式——命令模式(Commend)
- 普通用户下ifconfig:commend not found 解决方法
- Oracle 10g Advanced Replication
- OpenLayers3-10-Advanced View Positioning
- lsnrctl command not found,sqlplus commend not found
- Advanced SQL functions in Oracle 10g
- Advanced Programming in UNIX Environment Episode 10
- Olly Advanced 1.26 Beta 10 by MaRKuS_TH-DJM
- IOS 模拟器获取创建的数据库路径(个人)
- PLSQL编译存储过程无响应
- 2013年09月26日
- Windows编程轻松实现
- 全面剖析Cocos2d游戏触摸机制 (上)
- 10 Advanced git commend
- android 消息推送
- E: 无法获得锁 /var/cache/apt/archives/lock - open (11 资源临时不可用)
- String、StringBuffer与StringBuilder的区别
- Android开发_如何设置按钮背景透明与半透明_图片背景透明
- eclipse中添加中文api文档解释
- Android工程的编译过程
- Eclipse快捷键
- 将博客搬至CSDN
程序博客网,程序员的互联网技术博客家园。csdn论坛精品 msdn技术资料都在这里