版本控制器:Git

## 版本控制器:Git

```python
"""
github:代码社区
svn:版本控制器
git:版本控制器

版本控制器:可以管理编写的代码的仓库(文件夹),可以记录对仓库中所有被监测文件的任意操作过程

多个人协同开发,一定会遇到代码整合 - 方便程序员完成代码整合
目的:达到多人协同开发

git:分布式集群、多分支管理
"""
``
### 安装
```python
"""
1.下载对应版本:https://git-scm.com/download
2.安装git:在选取安装路径的下一步选取 Use a TrueType font in all console windows 选项
-- 安装成功后桌面右键可以看到git菜单
"""
```
### 工作流程图

 

 

### 搭建本地git仓库

##### 将已有的文件夹作为git仓库

```python
"""
>: cd 目标文件夹内部
>: git init
"""
```

##### 在指定目录下创建git仓库

```python
"""
>: cd 目标目录
>: git init 仓库名
"""
```
### 配置操作git的用户信息

##### 当前仓库:局部

```python
"""
>: git config user.name '用户名'
-- 用户名
>: git config user.email '用户邮箱'
-- 用户邮箱

eg:
>: git config user.name 'jason'
>: git config user.email 'jason@163.com'
"""
```

##### 所有仓库:全局

```python
"""
>: git config --global user.name '用户名'
>: git config --global user.email '用户邮箱'
"""
```

### 常用指令

##### 查看仓库状态

```python
"""
# 当仓库中有文件增加、删除、修改,都可以在仓库状态中查看
>: git status
-- 查看仓库状态
>: git status -s
-- 查看仓库状态的简约显示
"""
```

##### 工作区操作

```python
# 通过任何方式完成的文件删与改
# 空文件夹不会被git记录
```

##### 撤销工作区操作:改、删

```python
"""
>: git checkout .
-- 撤销所有暂存区的提交
>: git checkout 文件名
-- 撤销某一文件的暂存区提交
"""
```

##### 工作区内容提交到暂存区

```python
"""
>: git add .
-- 添加项目中所有文件
>: git add 文件名
-- 添加指定文件
"""
```

##### 撤销暂存区提交:add的逆运算

```python
"""
>: git reset HEAD .
-- 撤销所有暂存区的提交
>: git reset 文件名
-- 撤销某一文件的暂存区提交
"""
```

##### 提交暂存区内容到版本库

```python
# git commit -m "版本描述信息"
```

##### 撤销版本库提交:commit的逆运算

```python
"""
回滚暂存区已经提交到版本库的操作:
查看历史版本:
>: git log
>: git reflog
查看时间点之前|之后的日志:
>: git log --after 2018-6-1
>: git log --before 2018-6-1
>: git reflog --after 2018-6-1
>: git reflog --before 2018-6-1
查看指定开发者日志
>: git log --author author_name
>: git reflog --author author_name
回滚到指定版本:
回滚到上一个版本:
>: git reset --hard HEAD^
>: git reset --hard HEAD~1
回滚到上三个版本:
>: git reset --hard HEAD^^^
>: git reset --hard HEAD~3
回滚到指定版本号的版本:
>: git reset --hard 版本号
>: eg: git reset --hard 35cb292
"""
```

 

 

### 过滤文件

```python
# .gitignore 文件
# 1)在仓库根目录下创建该文件
# 2)文件与文件夹均可以被过滤
# 3)文件过滤语法

""" 过滤文件内容
文件或文件夹名:代表所有目录下的文件或文件夹都被过滤
/文件或文件夹名:代表仓库根目录下的文件或文件夹被过滤
/目录/文件或文件夹名:代表特定目录下的文件或文件夹被过滤
*可以出现在任何位置,代表模糊匹配

在仓库刚刚初始化就应该设置过滤规则(过滤文件本身不用被过滤)
"""
```

 

### git vs svn

```python
# 1、git是分布式的,每一个客户端均可以作为服务器为其他客户端提供代码
# 2、git有强大的分支管理机制,可以在子分支上开发,将最终的成果同步到主分支即可
```

 

posted @ 2021-05-27 18:20  FFLYY  阅读(38)  评论(0编辑  收藏  举报