git常用方法
data:image/s3,"s3://crabby-images/0d496/0d49662a8393d5c56381f909fd227475522e6ad7" alt=""
1.文件在各个区域的状态
data:image/s3,"s3://crabby-images/dc4ed/dc4ed8854459a0257d86698f6407c6205847cf52" alt=""
data:image/s3,"s3://crabby-images/2b53a/2b53a42c1a0ee3c307b9e46471a5736bd8e9f3a9" alt=""
data:image/s3,"s3://crabby-images/fa2b5/fa2b5b2975df9b5c67bfaa7ebfb20f7fd18b0e47" alt=""
data:image/s3,"s3://crabby-images/7d436/7d4366f96886f114c0c239b3aee80c90a78fbac4" alt=""
对于直接添加进git仓库而没有进行管理的文件,执行git status
会提示:untracked files
data:image/s3,"s3://crabby-images/c28fe/c28fe5a7e9c609be802f0e45413b12bbb1f51c7e" alt=""
说明git已经检测到文件了,但是没有进行跟踪,此时需要纳入到git管理中,执行git add
命令,可以只选个其中若干文件,git add file
,或者一次性全部加进来,git add .
可以把`add`指令理解为加入购物车
data:image/s3,"s3://crabby-images/8c08f/8c08fa3fb360fd294f9724e381a94c86f082533e" alt=""
此时的文件已经可以进行提交了,使用
git commit -sm '此次变更的总结'
。当然如果反悔了也可以根据git的提示,进行git reset HEAD <file>
。文件又会回到未跟踪状态。
不幸的是,Microsoft的Word格式是二进制格式,因此,版本控制系统是没法跟踪Word文件的改动的,
data:image/s3,"s3://crabby-images/1e5dc/1e5dc265d2196a57e9df306aeb7916b65c30251d" alt=""
所以文章开头的图只能装逼,如果要真正使用版本控制系统,就要以纯文本方式编写文件。
2.编辑已经提交的commit
如果刚不小心写错了commit信息,可以使用git commit --amend
会默认打开编辑器,修改commit信息后:wq
即可
如果在上次漏掉一个文件后,也可以修改后先git add <file>
再执行此命令,将此次修改合并到上一次commit
3.版本回退
我们执行的每一次命令,git都会有记录,git reflog
可以查看操作历史。其中
HEAD指向的版本就是当前指向的版本,使用命令git reset --hard commit_id
。
注意参数--hard
,重置HEAD并且丢弃本地未提交的变更,--soft
则会在重置HEAD的同时保留未提交的变更。
穿梭前,用git log可以查看提交历史,以便确定要回退到哪个版本。
要重返未来,用git reflog查看命令历史,以便确定要回到未来的哪个版本。
该git reflog用来记录你的每一次命令
data:image/s3,"s3://crabby-images/f4753/f4753b94ccf7fefa833b42f099a8e6657f9bdb84" alt=""
4.分支管理
data:image/s3,"s3://crabby-images/ddda1/ddda1fa4458e8d2a7c263fbb9f7b6ea9cd419175" alt=""
【git merge】
data:image/s3,"s3://crabby-images/71b51/71b511d35669149e7003ebde5a3a7036c9518d71" alt=""
data:image/s3,"s3://crabby-images/a9d25/a9d25faa2f0582412aa7bee441c67e979586a23d" alt=""
data:image/s3,"s3://crabby-images/3cd29/3cd297c5e744feac34ba2211320ce7c7fa466da7" alt=""
data:image/s3,"s3://crabby-images/953bc/953bcd1f868aa03ebab7ca3f65973b1e12e713e4" alt=""
data:image/s3,"s3://crabby-images/5983b/5983b3aca232f9277db9cd79d473dc79b9d74654" alt=""
注意到上面的Fast-forward信息,Git告诉我们,这次合并是“快进模式”,也就是直接把master指向dev的当前提交,当然我也可以保留此次合并,所以我们通过强制git产生一个真正的merge---通过使用--no-ff参数(no fast forward的意思)
【git rebase vs git merge】
两种用法:
1)针对一些本地提交进行重新编辑,合并commit
。
data:image/s3,"s3://crabby-images/0d285/0d285c04d91c0e91e59b5855e18c13bf119410d8" alt=""
2)在合并代码时进行变基操作,使得提交历史线性直观。
data:image/s3,"s3://crabby-images/f4ecf/f4ecf5cbc7df6fdfa0c0ddc8143e95b2d622ea4f" alt=""
data:image/s3,"s3://crabby-images/2a1f9/2a1f9de3de49e593cceb014f8051ae9ffdc7d2a4" alt=""
其他一些补充
git cherry-pick : 将一个已经存在的commit应用到其他分支上
git stash:暂存当前工作区的内容
git config --global alias.me 'merge'
git log --oneline -5
git revert