1.下载安装Git(略)
2.打开git bash窗口
3.查看版本号、设置用户名和邮箱
用户名和邮箱可以随意起,与GitHub的账号邮箱没有关系
data:image/s3,"s3://crabby-images/2dd3a/2dd3a84ce0e7ab788e02d8e00080732493088065" alt=""
4.初始化git
在D盘中新建gitspace文件夹,并在该目录下打开git bash窗口
git init
初始化完成后会在该目录下创建.git文件,此文件为隐藏文件,用可用ll -a命令查看
data:image/s3,"s3://crabby-images/31d56/31d563641ef4f4ab260121d1626c46f2de21f0ac" alt=""
5.查看本地库状态
git status
由于目录下没有文件,查看本地库状态时显示nothing to commit
用vim编辑一个hello.txt文件
data:image/s3,"s3://crabby-images/19548/195489fac2f20abc491dd345b5d5e14878a70c38" alt=""
data:image/s3,"s3://crabby-images/35e80/35e800fd27e96da679a131333e3f8baf062723b9" alt=""
再次查看本地库状态,提示Untracked files,表示目录下有未被追踪的文件
用git add hello.txt命令使hello.txt文件添加至暂存区
接着再查看本地库状态,提示文件可提交至本地库
data:image/s3,"s3://crabby-images/a515b/a515b05e1b65a7925e56ed4a6787cb933cd638cf" alt=""
将文件从暂存区中删除git rm --cached hello.txt
可以看到只是将暂存区的文件删掉,而本地磁盘中的文件任然存在
再次查看本地库状态,hello.txt文件又变成未追踪状态
data:image/s3,"s3://crabby-images/6688e/6688e501335113c976ef1a6775be066dc6596bd2" alt=""
再次添加hello.txt文件至暂存区,这次将文件提交至本地库,并查看本地库状态
git add hello.txt
git commit -m "first commit" hello.txt
data:image/s3,"s3://crabby-images/3f72b/3f72b1dc0a677fb12ab3e4ec30fac776de2d696b" alt=""
此时已将hello.txt成功提交至本地库,并且可以查看日志
git reflog
git log
reflog为精简日志
log为详细日志
data:image/s3,"s3://crabby-images/56dbe/56dbeb976f594bac344f84472e43086918fe740b" alt=""
如果再次修改hello.txt文件,查看本地库状态,hello.txt又变成为追踪状态
再次将文件添加至暂存区并提交至本地库
data:image/s3,"s3://crabby-images/60635/606352381bf570bbcfae086416eae2c7ed9b3ef0" alt=""
查看日志,之前一个版本现在变为了两个
data:image/s3,"s3://crabby-images/506a5/506a532fa5509d9576bee09b2a5b836c50a7e33e" alt=""
版本穿梭(回到指定版本)
使master指向指定的版本地址,比如说想穿梭到第一次commit的版本
git reset --hard 4dcbaf8
data:image/s3,"s3://crabby-images/db15c/db15c9233d6144dab6a013d97284762aba85f006" alt=""
6.git分支
查看分支 git branch -v
创建新的分支 git branch hot-fix
跳转分支 git checkout hot-fix
data:image/s3,"s3://crabby-images/c3f43/c3f43aef69bd999ee4959df380577dc1bfe3aaf5" alt=""
在hot-fix分支下修改hello.txt
data:image/s3,"s3://crabby-images/3c935/3c93544df0944480cb7747b2eb0c8337712d5b96" alt=""
查看日志,HEAD指向hot-fix
切换至master分支,master分支下的hello.txt并未改变
data:image/s3,"s3://crabby-images/20e2f/20e2f0c9452641e2e0462b79348997d5d045e9f0" alt=""
合并分支
git merge hot-fix
data:image/s3,"s3://crabby-images/6575d/6575d80006aada35430857aa75e1108bf52dab55" alt=""
此时master下的hello.txt已被修改
data:image/s3,"s3://crabby-images/780a0/780a066b610abbe86395adfc38b547601e18f704" alt=""
合并冲突,如果master和hot-fix分支同时修改文件并提交至本地库,用普通合并会报错
首先在master分支下在最后第二行添加master test,并提交
data:image/s3,"s3://crabby-images/e4c28/e4c289749e35248d39b2f6992746b9c078704cc6" alt=""
切换至hot-fix分支在最后一行添加hot-fix test,并提交
data:image/s3,"s3://crabby-images/fd121/fd12164779f39d0af1b75bb5aebe4b2334565fd1" alt=""
切换至master分支合并hot-fix
git merge hot-fix
data:image/s3,"s3://crabby-images/08c84/08c846770dac9f19260e47bf6589fd7eadf35867" alt=""
查看状态,显示master分支正在合并中
进入hello.txt文件并编辑,将不需要的内容删除
提交时不需要指定文件名,因为两个分支都修改了hello.txt,如果带文件名会报错,系统不知道要提交哪个hello.txt
data:image/s3,"s3://crabby-images/58492/5849250e94f23121bae379161283ce9d69c89eae" alt=""
此时再查看文件已经修改成功
data:image/s3,"s3://crabby-images/ecf44/ecf441f75b6c40d43cddae1d73ba8cd30e575593" alt=""