版权声明:Copyright © https://cloud.tencent.com/developer/article/1477132
sudo apt-get install git
在桌面上创建test文件夹,表示工作项目
cd ~/Desktop/test
git init
git config user.name 'zheng'
git config user.email 'zheng@163.com'
配置个人信息后,会在.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 -- 文件名
总结
提示: 多人协同开发时,避免不了会出现代码冲突的情况
原因: 多人同时修改了同一个文件
危害: 会影响正常的开发进度
注意: 一旦出现代码冲突,必须先解决再做后续开发
原则: 谁冲突谁解决,并且一定要协商解决
方案: 保留所有的代码,或者 保留某一个人的代码
解决完冲突代码后,依然需要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