1.git clone 把远程库克隆到本地文件夹
git clone -b dev https://gitee.com/XXX/EmpManage //直接克隆远程dev分支到本地dev分支
//相当于如下操作
git clone https://gitee.com/XXX/XXXManage //克隆远程仓库主分支
cd XXXManage
git status //查看当前状态
git branch -a //查看所有分支
//git branch -d dev //删除分区命令
git checkout -b dev //当前PC本地仓库创建一个新分区
git pull origin dev //拉取远程origin/dev分支到当前路径(git branch dev remotes/origin/dev)
git checkout dev //切换到dev分支
2.编辑本地仓库文件并提交到本地信息库(git add ./git commit)
nano README.md //读取README.md文件中内容
...
git add . //git add --all //git add AAA.hpp bbb.cpp
git commit -m “x修改信息” //提交当前状态到本地分支并附上修改信息
3.将本地库提交到远程Git服务器
//首次提交需要确认当前已设定用户名及邮箱 ,命令git config user.name 和git config user.email
git remote -v //如果有必要,需查看当前项目所有远程仓库源,确保远程仓库源已设定,例如orign已有值。如果没有可以输入命令git remote add origin git@gitee.com:XXX/123.git ,其中git为GIT管理平台https/ssh协议路径
git push origin dev //推送当前最新提交状态到origin远程仓库的dev分支
//git log --oneline --graph //查看分支日志,graph表示图形化显示
4.本地回退某版本或某提交状态
//刚提交,欲在此修改并合并入上次提交(这次提交合并入上次提交)
git add a.txt
git commit -–amend –-no-edit
//若也想修改message,将--no-edit换为-m "XXX"
//git返回之前某版本
git reset --hard //查看当前版本标志,以及备注内容
git reset --hard HEAD^ //^表示回退前一个版本,^^表示前两个版本,~100表示前100版本
git reset --hard 822ad73 //表示回退至822ad73标识符版本,通过git log查看
//返回之后的某个版本
git reflog //查看所有操作日志及标识
git reset --hard HEAD@{3} //返回看3号版本
//回退到某版本,或使某个文件(某文件变化回退前版本,但是其他不变)
git log --oneline
git checkout c676a1a
git checkout c676a1a --test.txt
5.创建及合并分支
git branch dev //创建分支
git branch -d dev //删除分区
git checkout -b dev //创建一个新分区
git commit -am “change3 ” //直接提交,不用add.但仅对已添加的内容提交
//合并项目
git merge --no-ff -m “keep merge info” dev //--no-ff 表示no fast forward
//合并项目
git checkout dev
git rebase master //将主分支合并到dev分支,便于版本维护。分支版本并不会乱
git add 1.py
git rebase -–continue
git log -–oneline –-graph
//合并主分支项目某提交到本分支
git checkout dev
git cherry-pick master 4a26asd
6.暂存当前分支开发状态,之后再恢复
git checkout dev
git stash push -a /第一步,存储当前dev开发状态,包含忽略文件
git checkout -b boss //创建boss分支
… //在boss分支 增添改查等操作
git checkout master //切换至master分支
git merge –-no-ff -m “merged boss job” boss //将刚才boss分支合并到主分支
git checkout dev //切换到dev分支最新节点
git stash pop /第二部,返回修改