git 基本命令

git学习:Git教程 - 廖雪峰的官方网站

1. 创建版本库
mkdir		创建目录
cd			进入目录
pwd			显示当前目录
git init 	把这个目录变成Git可以管理的仓库
2. 提交文件到本地仓库
git add				添加到暂存区
git commit -m "注释"	提交到仓库
在使用git add提交多个文件的方式:
git add .	提交被修改的和新建的文件,但不包括被删除的文件                            
git add -u --update	update tracked files    更新所有改变的文件,即提交所有变化的文件
git add -A --all	add changes from all tracked and untracked files   提交已被修改和已被删除文件,但是不包括新的文件
追加修改
git commit --amend
shift + q,  wq!保存退出
3. 管理修改
git status				查看工作区修改
git diff				查看修改内容
git checkout + 文件名	撤销工作区的修改
推荐工具:Kaleidoscope(Mac)git difftool 对比修改
git log										查看提交历史
git reflog									查看命令历史
git reset + log/reflog里面某条修改记录的地址	回退到该位置
git reset hard								彻底清除
4. 与远程仓库协作
git clone + 地址							克隆远程仓库到本地
git pull --rebose						更新远程分支到本地
git push origin HEAD:/refs/for/分支名	提交到远程仓库
5. 分支管理
git branch -r			查看所有分支
git checkout + 分支名	切换到指定分支
git branch				查看当前所在分支

推荐zsh提高shell逼格:oh-my-zsh

oh-my-zsh配置你的zsh提高shell逼格终极选择

6. git丢弃本地修改的所有文件(新增、删除、修改)
git checkout . #本地所有修改的。没有的提交的,都返回到原来的状态
git stash #把所有没有提交的修改暂存到stash里面。可用git stash pop回复。
git reset --hard HASH #返回到某个节点,不保留修改。
git reset --soft HASH #返回到某个节点。保留修改

git clean -df #返回到某个节点
git clean 参数
    -n 显示 将要 删除的 文件 和  目录
    -f 删除 文件
    -df 删除 文件 和 目录
7. 使用git stash命令保存和恢复进度

我们有时会遇到这样的情况,正在dev分支开发新功能,做到一半时有人过来反馈一个bug,让马上解决,但是新功能做到了一半你又不想提交,这时就可以使用git stash命令先把当前进度保存起来,然后切换到另一个分支去修改bug,修改完提交后,再切回dev分支,使用git stash pop来恢复之前的进度继续开发新功能。

git stash

保存当前工作进度,会把暂存区和工作区的改动保存起来。执行完这个命令后,在运行git status命令,就会发现当前是一个干净的工作区,没有任何改动。使用git stash save 'message...'可以添加一些注释

git stash list

显示保存进度的列表。也就意味着,git stash命令可以多次执行。

git stash pop [–index] [stash_id]
  • git stash pop 恢复最新的进度到工作区。git默认会把工作区和暂存区的改动都恢复到工作区。
  • git stash pop --index 恢复最新的进度到工作区和暂存区。(尝试将原来暂存区的改动还恢复到暂存区)
  • git stash pop stash@{1}恢复指定的进度到工作区。stash_id是通过git stash list命令得到的,通过git stash pop命令恢复进度后,会删除当前进度。
git stash apply [–index] [stash_id]

除了不删除恢复的进度之外,其余和git stash pop 命令一样。

git stash drop [stash_id]

删除一个存储的进度。如果不指定stash_id,则默认删除最新的存储进度。

git stash clear

删除所有存储的进度。

**小记:**曾经自己学习git,就是add和commit,也没什么用,主要还是自己写代码不多。到了公司以后,真正将git应用到了实践中,再次学习这些命令,再看一遍廖雪峰老师的git教程,发现以前看了一遍就忘记的东西竟然现在觉得深以为然,“对,就是这样的”和“哦,原来如此”。果然学以致用,实践是检验真理的唯一标准,加油吧,少年!

你可能感兴趣的:(计算机基本操作,git,git,github,基本命令)