一、git基本操作
1、git的结构
-
git工作结构分为三个区域:工作区、临时存储区、本地库,三者之间的关系如图所示(写代码是在工作区完成-->add-->临时存储区stage-->commit-->本地仓库)
2、git基本命令
(1)创建本地版本库
git init命令是初始化本地仓库
- 先打开Git Bash命令行界面:
Administrator@BF-20180604CDXI MINGW64 ~/Desktop
$ mkdir demo
Administrator@BF-20180604CDXI MINGW64 ~/Desktop
$ cd demo
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo
$ pwd
/c/Users/Administrator/Desktop/demo
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo
$ git init//初始化本地仓库
Initialized empty Git repository in C:/Users/Administrator/Desktop/demo/.git/
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
$ ll -a//查看本地仓库目录下文件,.git/为隐藏文件
total 20
drwxr-xr-x 1 Administrator 197121 0 九月 15 23:47 ./
drwxr-xr-x 1 Administrator 197121 0 九月 15 23:47 ../
drwxr-xr-x 1 Administrator 197121 0 九月 15 23:47 .git/
(2)提交文件到本地仓库
git add把写好的代码从工作区提交到临时存储区stage
git commit 把临时区的代码提交到本地仓库
git status 查看状态(工作区,临时区的状态)
git log查看历史提交版本
git log --oneline整洁的查看历史提交版本
git reflog可以查看所有分支的所有操作记录
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
$ vim demo//1、在工作区中创建一个文件
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
$ git status//2、查看状态(此刻还在工作区中)
On branch master
No commits yet
Untracked files:
(use "git add <file>..." to include in what will be committed)
demo
nothing added to commit but untracked files present (use "git add" to track)
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
$ git add ..//3、从工作区添加到临时区
warning: LF will be replaced by CRLF in demo.
The file will have its original line endings in your working directory.
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
$ git status//4.查看状态(此时在临时区了)
On branch master
No commits yet
Changes to be committed:
(use "git rm --cached <file>..." to unstage)
new file: demo
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
$ git log//5、查看历史提交记录(此时没有历史提交记录)
fatal: your current branch 'master' does not have any commits yet
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
$ git commit -m "demo"//6、提交代码到本地仓库
[master (root-commit) fed3895] demo
1 file changed, 1 insertion(+)
create mode 100644 demo
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
$ git status//7、查看状态(此时在本地仓库了)
On branch master
nothing to commit, working tree clean
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
$ git log//8、查看历史提交记录(此时有一条记录commitid=fed3895exxx)
commit fed3895eef27f31ec8a0b0642223e5742bb22d02 (HEAD -> master)
Author: qiuzhangwei <2608442616@qq.com>
Date: Sun Sep 16 00:02:33 2018 +0800
demo
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
$ git reflog//9、整洁的查看历史
fed3895 (HEAD -> master) HEAD@{0}: commit (initial): demo
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
$
(3)回退修改(回退modified文件)
- 修改后,还没有add到临时区
git checkout -- 文件(放弃改变在工作区)
- add到临时区但是没有commit到本地仓库
先git reset HEAD 文件(从暂存区回到工作区)
然后git checkout -- 文件(放弃改变在工作区)
- 已近commit到了本地仓库
git reset --hard 版本号或HEAD^或HEAD~n(本地仓库回退到之前的版本)
(4)其他基本操作
git status 状态查看(工作区、暂存区状态)
git log查看历史记录
git reflog查看简介的历史记录
git diff 比较文件差异(将工作区中的文件和暂存区进行比较)
3.分支管理
(1)概念
在版本控制过程中,使用多条线同时推进多个任务。
(2)分支好处
- 同时并行推进多个功能开发,提高开发效率
- 各个分支在开发过程中,如果某一个分支开发失败,不会对其他分支有任何影响。失败的分支删除重新开始即可
(3)分支基本操作
git branch [分支名]创建分支
git branch -v查看分支
git checkout [分支名]切换分支
git branch -d [分支名]删除未提交的分支
git branch -D [分支名]强制删除一个已经提交了的分支
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
$ git branch -v//查看当前分支
* master f302b1c sdf
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
$ git branch dev//创建dev分支
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
$ git checkout dev//切换到dev分支
Switched to branch 'dev'
Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (dev)
$ git branch -v//查看当前分支
* dev f302b1c sdf
master f302b1c sdf
(4)使用merge分支合并
第一步:切换到接受修改的分支(被合并,增加新内容)上
git checkout [被合并分支名]
第二步:执行 merge 命令
git merge [有新内容分支名]
第三步:解决冲突如果有冲突的话
-->打开冲突文件
-->把文件修改到满意的程度,保存退出
-->git add [文件名]
-->git commit -m "日志信息"
案例:
在master分支上
1、vim a.txt
a1
2、git add和git commit提交到本地仓库
切换到dev分支
3、git checkout dev
4、vim a.txt
a2
5、git add和git commit提交到本地仓库
切换回master分支进行合并
6、git merge dev--产生冲突
7、vim a.txt进行冲突解决
----------------------------当前分支内容--------------------------
<<<<<<< HEAD
a1
=======
----------------------------需要合并的分支内容--------------------------
a2
>>>>>>> dev
8、解决冲突后vim a.txt
a1
a2
9、进行git add 和git commit就完成了分支的合并
(5)使用rebase合并分支
第一步:切换到接受修改的分支(被合并,增加新内容)上
git checkout [被合并分支名]比如develop
第二步:执行 rebase命令
git rebase[有新内容分支名]比如master
第三步:解决冲突如果有冲突的话
-->打开冲突文件
-->把文件修改到满意的程度,保存退出
-->git add [文件名]
-->git rebase --continue
-->推到远程仓库然后进行取出冲突
-->如果要放弃这次合并,使用git rebase --abort
第四步:快进式合并一下,移动 master 的指针指向最新的提交
git merge master develop