1. 本地库初始化
#初始化本地库
git init
注意:.git
目录中存放的是本地库相关的子目录和文件,不要删除,也不要胡乱修改。
2. 设置签名
- 形式
用户名:tom Email地址:[email protected]
- 作用:区分不同开发人员的身份
- 辨析:这里的设置的签名和登录远程库(代码托管中心)的账号、密码没有任何关系。
- 命令
- 项目级别/仓库级别:仅在当前本地库范围内有效
git config user.name test git config user.email [email protected] # 信息保存位置:./.git/config 文件
- 系统用户级别:登录当前操作系统的用户范围
git config user.name test git config user.email [email protected] #信息保存位置:~/.gitconfig 文件
- 级别优先级
- 就近原则:项目级别优先于系统用户级别,二者都有时采用项目级别的签名;
- 如果只有系统用户级别的签名,就以系统用户级别的签名为准
- 二者都没有不允许
- 项目级别/仓库级别:仅在当前本地库范围内有效
3. 基本操作
3.1 状态查看
#查看工作区、暂存区状态
git status
3.2 添加
#将工作区的”新建/修改“添加到暂存区
git add [file name]
3.3 提交
#将暂存区的内容提交到本地库
git commit -m "commit message" [file name]
3.4 查看历史记录
git log
- 多屏显示控制方式:
- 空格向下翻页;
- b 向上翻页;
- q 退出;
git log --pretty=oneline
git log --oneline
git reflog
HEAD@{移动到当前版本需要多少步}
3.5 前进后退
- 基于索引值操作【推荐】
git reset --hard [局部索引值] #git reset -- hard a6ace91
- 使用
^
符号:只能后退git reset --hard HEAD^ #一个 ^ 表示后退一步,n个表示后退n步
- 使用
~
符号:只能后退git reset --hard HEAD~n #表示后退n步
3.6 reset命令的三个参数对比
--soft
:参数- 仅仅在本地库移动 HEAD 指针
--mixed
:参数- 在本地库移动HEAD指针
- 重置暂存区
--hard
:参数- 在本地库移动 HEAD 指针
- 重置暂存区
- 重置工作区
3.7 删除文件并找回
- 前提:删除前,文件存在时的状态提交到了本地库。
- 操作:
git reset --hard [指针位置]
- 删除操作已经提交到本地库:指针位置指向历史记录
- 删除操作尚未提交到本地库:指针位置使用HEAD
3.8 比较文件差异
#将工作区中的文件和暂存区进行比较
git diff [文件名]
#讲工作区中的文件和本地库历史记录比较
git diff [本地库历史版本] [文件名]
#不带文件名比较多个文件
4. 分支管理
4.1 什么是分支
在版本控制过程中,使用多条线同时推进多个任务。
4.2 分支的好处
- 同时并行推进多个功能开发,提高开发效率
- 各个分支在开发过程中,如果一个分支开发失败,不会对其他分支有任何影响。失败的分支删除重新开始即可。
4.3 分支操作
#创建分支
git branch [分支名]
#查看分支
git branch -v
#切换分支
git checkout [分支名]
#合并分支
#第一步:切换到接收修改的分支(被合并,增加新内容)上
git checkout [被合并分支名]
#第二步:执行merge命令
git merge [有新内容分支名]
- 解决冲突
- 冲突的表现
- 冲突的表现
- 冲突的解决
- 第一步:编辑文件,删除特殊符号
- 第二步:把文件修改到满意的程度,保存退出;
- 第三步:git add [文件名]
- 第四步:git commit -m “日志信息”
- 注意:此时 commit 一定能带具体文件名