git版本控制

git版本控制

安装git

1. linux 安装

sudo apt-get install git

2. 查看安装结果 git

3. 创建项目

在桌面上创建test文件夹,表示工作项目

4. 创建本地仓库

  • 进入test,创建本地仓库 .git
  • 新创建的本地仓库 .git 是个空仓库
  • 创建本地仓库后 test会有一个.git 文件夹
cd ~/Desktop/test
git init

5. 配置个人信息

git config user.name 'zheng'
git config user.email '[email protected]'

配置个人信息后,会在.git文件夹下面出现刚配置的个人信息

命令

git status 查看文件状态 (如果文件名红色,证明在工作区)
git add . 添加项目中所有文件 添加文件到暂存区
git add 文件名 添加指定文件到暂存区
(此时文件名是绿色的)

# 将暂存区的文件提交到仓库区
git commit -m '版本描述'

git status 无文件提交,干净的工作区

git commit -am '版本描述'

# 查看历史
git log
git reflog

# 回退版本
方案一

HEAD表示当前最新版本

HEAD^表示当前最新版本的前一个版本

HEAD^^表示当前最新版本的前两个版本

方案二

通过每个版本的版本号回退到指定版本


....
git reset --hard HEAD^

git reset --hard 版本号

# 撤销更改
- 只能撤销工作区、暂存区的代码,不能撤销仓库区的代码

- 撤销仓库区的代码就相当于回退版本操作

# 撤销工作区的代码
git checkout 文件名

# 撤销暂存区的代码
1. 将暂存区代码撤销到工作区 git reset HEAD 文件名
2. 撤销工作区代码 git checkout 文件名

#对比版本
#对比版本库到工作区
git diff HEAD -- 文件名

#对比版本库

git diff HEAD HEAD^ --login.py


# 删除文件
确认删除
rm 文件名

# git 确定删除文件,对比天剑文件git add
git rm 文件名

# 删除后记录删除操作版本
git commit -m '删除描述'


误删
# 删除文件
rm 文件名
# git 撤销修改
git checkout -- 文件名

git 远程仓库 GitHub

克隆仓库 git clone

拉取仓库 git pull

推送到仓库 git push

总结

  • 要使用git命令操作仓库,需要进入到仓库内部
  • 要同步服务器代码就执行:git pull
  • 本地仓库记录版本就执行:git commit -am ‘版本描述’
  • 推送代码到服务器就执行:git push
  • 编辑代码前要先pull,编辑完再commit,最后推送是push

代码冲突

提示: 多人协同开发时,避免不了会出现代码冲突的情况
原因: 多人同时修改了同一个文件
危害: 会影响正常的开发进度
注意: 一旦出现代码冲突,必须先解决再做后续开发

解决冲突

原则: 谁冲突谁解决,并且一定要协商解决
方案: 保留所有的代码,或者 保留某一个人的代码
解决完冲突代码后,依然需要add、commit、push

补充

  • 容易冲突的操作方式

    • 多个人同时操作了同一个文件
    • 一个人一直写不提交
    • 修改之前不更新最新代码
    • 提交之前不更新最新代码
    • 擅自修改同事代码
  • 减少冲突的操作方式

    • 养成良好的操作习惯,先pull在修改,修改完立即commit和push
    • 一定要确保自己正在修改的文件是最新版本的
    • 各自开发各自的模块
    • 如果要修改公共文件,一定要先确认有没有人正在修改
    • 下班前一定要提交代码,上班第一件事拉取最新代码
    • 一定不要擅自修改同事的代码

打标签

在本地打标签

git tag -a 标签名 -m ‘标签描述’

推送标签到远程仓库

git push origin 标签名

删除标签

git tag -d 标签名

git push prigin –delete tag 标签名

分支

查看当前分支 git branch
创建并切换到dev 分支 git checkout -b dev
设置本地分支跟踪远程制定分支 git push -u origin dev

dev 分支合并到master分支

切换到master分支 git checkout master
dev分支合并到master分支 git merge dev

合并分支到远程仓库 git push

猜你喜欢

转载自blog.csdn.net/zzw19951261/article/details/81148535
今日推荐