Git——分布式版本控制系统
介绍命令前先来说说git的三个工作区域:
1.working directory
仓库初始化后默认存放的位置
2.staging area(index)
add后暂存的位置
3.git repository
最终确定文件保存的位置
git config --global color.ui.true
打开文件颜色显示
git config --global user.name "myname"
设置git用户名
git config --global user.email "myemail"
设置git邮箱
git config -- list
查看设置
git init
初始化git仓库
git status
查看文件状态,可选参数-s
git add filename
把文件从working directory提交到staging area
git commit -m "message"
把文件从staging area提交到working directory
git commit -am "message"
直接将文件从working directory提交到git repository中(不建议使用)
git log
查看提交日志
--online
只显示commit的message
git diff
查看文件变更内容
--staged
查看staging area变更内容
--stat
查看working directory变更内容
git reset filename
把staging area中的文件恢复为git repository版本
--hard hash码
把staging area中的文件恢复为指定的git repository历史版本
git reset --mixed:此为默认方式,不带任何参数的git reset,即时这种方式,它回退到某个版本,只保留源码,回退commit和index信息
git reset --soft:回退到某个版本,只回退了commit的信息,不会恢复到index file一级。如果还要提交,直接commit即可
git reset --hard:彻底回退到某个版本,本地的源码也会变为上一个版本的内容
git checkout filename
把working directory中的文件恢复为staging area的版本
git checkout HEAD filename
把working directory中的文件恢复为git repository的版本
git relog
恢复历史版本后可使用此命令查看所有提交历史
git rm filename
把文件从本地git(working directory和staging area)中删除,再执行git commit -m "message"可以把git repository中的文件也删掉
--cached
把文件从staging area中删除
git mv filename newfilename
本地git文件改名
git stash
把working directory内容暂存并回退为最后提交时的版本
git stash list
查看暂存列表
git stash
pop
恢复为暂存的版本
tree
查看目录结构(头高头比拧家多只角)
git cat-file -p HEAD
显示HEAD指向的内容信息
git rev-parse HEAD
显示当前HEAD指向的hash码
git rev-parse HEAD~
显示上一级
HEAD指向的hash码
git rev-parse HEAD~4^{tree}
显示上4级tree指向的hash码
git rev-parse HEAD~4:filename
显示上4级文件指向的hash码
git cat-file -p HEAD~4:filename
显示上4级文件内容
git show HEAD~4:filename
效果与前一种写法一样
git branch
列出所有分支
git branch 分支名
创建分支
-d
删除分支
git checkout 分支名
切换到某个分支
-b
创建分支同时切换
git merge 分支名
使被merge分支的内容和当前分支内容合并