【Git】Git 相关知识,以及常见问题解决

Git的工作区域和流程

● Workspace:工作区,就是开发的时候的代码,通过git status可以查看
● Index:暂存区,通过git add 的命令可以将代码放到暂存区
● Repository:本地仓库,通过 git commit 提交暂存区的代码到本地仓库
● Remote:远程仓库,用来托管代码的服务器,通过git push将本地仓库的代码上传到远程仓库

规范(个人使用)
● 分支规范
○ 开发分支以feature/开头
○ 发版分支以release/开头
○ 修复bug,必须冲master拉取,以fix/打头
○ 开发完成后,合并到release/分支进行发版
○ 稳定运行后,将release分支代码合并到master分支

● 提交规范
feat:新功能(feature)
fix:修补bug
docs:文档(documentation)
style: 格式(不影响代码运行的变动)
refactor:重构(即不是新增功能,也不是修改bug的代码变动)
test:增加测试
chore:构建过程或辅助工具的变动

常见操作
● 分支操作

# 新建本地分支,但不切换
git branch <branch-name> 
# 查看本地分支
git branch
# 查看远程分支
git branch -r
# 查看本地和远程分支
git branch -a
# 删除本地分支
git branch -D <branch-nane>
# 重新命名分支
git branch -m <old-branch-name> <new-branch-name>

● 更新本地代码

# 从远程仓库拉取代码并合并到本地,可简写为 git pull 等同于 git fetch && git merge 
git pull <远程主机名> <远程分支名>:<本地分支名>
# 使用rebase的模式进行合并
git pull --rebase <远程主机名> <远程分支名>:<本地分支名>

# 获取远程仓库特定分支的更新
git fetch <远程主机名> <分支名>
# 获取远程仓库所有分支的更新
git fetch --all

注意:git fetch只是拉取远程的代码,不会自动合并

● 提交代码

## --------添加文件到暂存区

# 添加某个文件到暂存区,后面可以跟多个文件,以空格区分
git add xxx
# 添加当前更改的所有文件到暂存区。
git add .

## --------将暂存区代码提交到本地仓库

# 提交暂存的更改,会新开编辑器进行编辑
git commit 
# 提交暂存的更改,并记录下备注
git commit -m "you message"
# 等同于 git add . && git commit -m
git commit -am
# 对最近一次的提交的信息进行修改,此操作会修改commit的hash值
git commit --amend

## --------提交到远程仓库
git push

常见问题
● 想合并另一个分支的某一次提交
○ git cherry-pick
● 回退操作
○ git revert 创建新的commit记录来抵消之前的更新
○ git reset 直接回退commit记录
● 暂存更改
○ git stash 保存未提交的改动
○ git statsh pop 可以切换分支后,将之前保存的文件取出来
● git中不小心误删drop local commit如何恢复
○ git reflog
○ c27d274 (HEAD -> master) HEAD@{12}: commit: add spider
○ git reset --hard c27d274
● 取消还没有push的commit
○ git reset --soft HEAD^ 回退一个

你可能感兴趣的:(笔记,git,github)