- 协同开发工具(版本控制器)
目前使用最广泛的就是svn和git
主要作用:管理项目的版本,多人协同开发 - List item
svn和git帮我们管理项目
svn:集中式 git:分布式
Git
参考站点:https://www.liaoxuefeng.com/wiki/896043488029600/896067008724000
git是目前世界上最先进的分布式版本控制系统
### 安装Git
初始化git :电脑桌面右键打开 Git Bash Here 命令窗口,然后输入下面命令:
### 创建版本库
初始化版本库:在要操作的文件夹下打开GBH命令行窗口,执行 git init 后会生成一个 .git 文件,说明成功了。
【注意】:如果你使用Windows系统,为了避免遇到各种莫名其妙的问题,请确保目录名(包括父目录)不包含中文。
### 版本库的管理:
- 把要上传的文件添加到缓存区:git add 文件全名(git add * 会把所以文件添加)
- 添加到版本库:git commit -m '注释' 注释必须写
版本切换
查看仓库状态:git status : 查看文件是否被修改
- 修改文件之后通过git status查看会显示modified(红色)--->说明文件未提交
- 执行 git add 文件名 之后再次通过git status查看会显示 modified(绿色)--->表示提交到了缓存区,但是没有添加到版本库。最后执行 git commit -m '注释' 之后再次通过git status查看会显示 没有可提交的
- git diff : 查看具体修改的内容:
修改代码没有执行add和commit,此时通过 git diff 查看会显示出修改的内容。之后再提交到缓存区或者版本库 git diff 就不再监听。(回车认为删除)
历史
- git log : 查看历史提交版本(提交人,时间,注释,版本号)
- git log --pretty=oneline : 简化版的 git log (提交版本号,注释)
- git reset --hard HEAD^ :版本回退,一个^符号代表回退一个版本
- git reset --hard 版本号 :不小心回退到历史版本了,但是突然又不想回去了,执行这个命令
工作区 和 暂存区(缓存区)
工作区:当前写的代码的目录 缓存区:git add添加到缓存区 版本库:git commit添加到版本库
【注意】:可以多次add 一次性commit(可以多次通过 add 添加到缓存区,然后执行一次 commit 提交到版本库)
管理修改与撤销
1. 单纯修改了文件,没有add也没有commit git checkout -- 文件名 撤销刚刚的操作,撤销到提交的最后一个版本 2. 修改了文件,并且执行了add,但是没有commit: 先撤回add的操作:git reset HEAD 文件名 再撤回文件修改:git checkout -- 文件名 3. 修改了文件,执行了add和commit : 此时只能执行版本回退了 git reset --hard HEAD^
删除文件
1. 删除本地文件(add了但是没有commit):rm 文件名 2. 删除仓库文件(add了并且commit): rm 文件名 git rm 文件名 git commit -m '删除了xx文件' 3. 撤销删除(撤销的前提是缓存区或者版本库存在,只是本地没了;如果缓存区或版本库没有则无法恢复) 1. 创建一个文件之后,提交到缓存区或版本库,此时如果通过 rm 文件名 将本地文件删除之后又想恢复文件,则可以通过执行 git checkout -- 文件名 命令。 2. 创建一个文件之后,此时如果通过 rm 文件名 将本地文件删除之后又想恢复文件,则无法恢复。
分支管理:
分支目前在使用过程中主要有两种方式:
1. 子分支作为每个人的开发分支,目的是避免影响主分支及他人 2. 子分支也可以做为一个标准的版本进行存储
例子:github上swiper:2.x 3.x 4.x都是子分支
创建并切换到子分支:git checkout -b(branch 的简写) 分支名
· 子分支就是复制了一份主分支的内容,开辟了一个新的空间进行存储,此空间就是子分支
切换到主分支:git checkout master(在子分支修改代码后添加到缓存区并且提交到版本库,然后切换到主分支再查看代码会发现代码并没有修改,每个分支互不影响)
合并分支:git merge 子分支名(前提必须先切换到主分支,再执行合并子分支命令)
删除子分支:git branch -d 分支名
查看分支:git branch(左边有一个*号,指当前)
- 创建子分支:git branch 子分支名
分支冲突解决:
版本库只能存在一个版本
版本冲突的实质就是同时操作一个文件
解决方法 :
- 选择保留双方更改
- 手动解决冲突,合并两个人版本,然后删除不要部分,最后add到缓存区,commit到版本库
- 为了避免冲突,大家还是要避免操作同一个文件
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。