01.Git实用技巧
目录介绍
- 01.初始化配置Git
- 02.关联仓库的配置
- 03.代码提交和同步
- 04.代码撤销的操作
- 05.分支切换的操作
- 06.版本回退和前进
- 07.Git配置忽略文件
01.初始化配置Git
看看当前的配置
$ git config --list
编辑 Git 配置文件
$ git config -e [--global] #--global 表示设置全局配置,不加该参数只对当前仓库生效
设置提交代码时的用户信息
$ git config [--global] user.name "[name]"
$ git config [--global] user.email "[email address]" #别人看到你的commit可以联系到你
# --global为可选参数,该参数表示配置全局信息
02.关联仓库的配置
创建 SSH key
$ ssh-keygen -t rsa -C "email@example.com"
此时会生成 id_rsa 和 id_rsa.pub 两个文件,登录网站设置点击 Add SSH Key 在 key 文本里粘贴 id_rsa.pub 文件的内容
关联远程仓库
$ git remote add origin git@github.com:xxx/xxx.git
推送到远程 master 分支
$ git push -u origin master
03.代码提交和同步
3.1 提交流程示意图
代码提交和同步的流程图
3.2 代码提交流程
第一步: 文件增删改,变为已修改状态
第二步: git add ,变为已暂存状态
$ cd 名称 #进入提交文件目录
$ git status
$ git add --all # 当前项目下的所有更改
$ git add . # 当前目录下的所有更改
$ git add xx/xx.java xx/xx2.java # 添加某几个文件
第三步: git commit,变为已提交状态
$ git commit -m"<这里写commit的描述>"
第四步: git push,变为已推送状态
$ git push -u origin master # 第一次需要关联上
$ git push origin master # 绝大多数使用这个,master指分支,你可以指向其他分支
$ git push -u origin +master # 如果还是无法提交,可以尝试强制更新
$ git push # 之后再推送就不用指明应该推送的远程分支了
$ git branch # 可以查看本地仓库的分支
$ git branch -a # 可以查看本地仓库和本地远程仓库(远程仓库的本地镜像)的所有分支
在某个分支下,我最常用的操作如下
$ git status
$ git add -a
$ git status
$ git commit -m 'xxx'
$ git pull --rebase
$ git push origin xxbranch
04.代码撤销的操作
4.1 已修改但未暂存
已经修改了本地代码,但是还未暂存到本地git中
$ git diff # 列出所有的修改
$ git diff xx/xx.py xx/xx2.py # 列出某(几)个文件的修改
$ git checkout # 撤销项目下所有的修改
$ git checkout . # 撤销当前文件夹下所有的修改
$ git checkout xx/xx.py xx/xx2.py # 撤销某几个文件的修改
$ git clean -f # untracked状态,撤销新增的文件
$ git clean -df # untracked状态,撤销新增的文件和文件夹
# Untracked files:
# (use "git add <file>..." to include in what will be committed)
#
# xxx.py
4.2 已暂存未提交
这个时候已经执行过git add,但未执行git commit,但是用git diff已经看不到任何修改。 因为git diff检查的是工作区与暂存区之间的差异。
$ git diff --cached # 这个命令显示暂存区和本地仓库的差异
$ git reset # 暂存区的修改恢复到工作区
$ git reset --soft # 与git reset等价,回到已修改状态,修改的内容仍然在工作区中
$ git reset --hard # 回到未修改状态,清空暂存区和工作区
git reset --hard 操作等价于 git reset 和 git checkout 这2步操作
4.3 已提交未推送
执行完commit之后,会在仓库中生成一个版本号(hash值),标志这次提交。之后任何时候,都可以借助这个hash值回退到这次提交。
$ git diff <branch-name1> <branch-name2> # 比较2个分支之间的差异
$ git diff master origin/master # 查看本地仓库与本地远程仓库的差异
$ git reset --hard origin/master # 回退与本地远程仓库一致
$ git reset --hard HEAD^ # 回退到本地仓库上一个版本
$ git reset --hard <hash code> # 回退到任意版本
$ git reset --soft/git reset # 回退且回到已修改状态,修改仍保留在工作区中。
4.4 已推送到远程
慎用,一般情况下,本地分支比远程要新,所以可以直接推送到远程,但有时推送到远程后发现有问题,进行了版本回退,旧版本或者分叉版本推送到远程,需要添加 -f参数,表示强制覆盖。
$ git push -f orgin master # 强制覆盖远程分支
$ git push -f # 如果之前已经用 -u 关联过,则可省略分支名
05.分支切换的操作
06.版本回退和前进
07.Git配置忽略文件
https://www.jianshu.com/p/74bd0ceb6182