• Git常用命令操作总结


    获取版本库

    git init

    git clone


    版本管理

    git add  常用 git add .

    git commit / git commit -am '注释' (跳过git add) /git commit -m '注释'

    git rm


    查看信息

    git help

    git status

    git log  带图git graph / 之前的操作查看 git reflog 

    git diff : 工作区和暂存区差异性比较

    git diff HEAD: 最新的提交与工作区差异性比较 HEAD可换 commit_id

    git diff --cached commit_id : 暂存区去提交的差别,不写commit_id是与最新的提交比较。

    git blame + <文件名>:显示上一次修改的作者信息以及是哪个修订


    回退版本

      回到上一个版本:

        git reset --head HEAD^      :回几个版本加几个^

        git reset --head HEAD~1

      回到某个版本

        git reflog 找id前五位

        git reset --head <commit id>

      git reset HEAD  <文件名> : 将之前添加到暂存区中最后一次添加的文件内容,从暂存区移到工作区


    丢弃变更 checkout和 stash

      git checkout -- <文件名> : 丢弃相对于暂存区中最后一个添加文件内容所做的变更 ,改的是工作区

        保存现场

        git stash  save <说明>:将正在进行的工作状态临时保存起来。

            git stash list:列表查看临时

        恢复现场

        git stash pop:降临时保存的状态取出,并删除临时

            git stash apply stash@{0} :stash内容不删除,删除用 git stash drop stash@{0} 手动删除

        


    分支操作

      git branch :查看分支,-a  查看远程分支

        git checkout <分支名>

        git checkout <commit id>

        git checkout - :回到上一个分支

        git branch -m <分支名> <分支名1> : 分支改名

       


     标签

         有两种标签:轻量级标签和带有附注标签

       创建轻量级标签 :git tag v1.0.1

       创建带有附注标签:git tag -a v1.0.1 -m 'release version'

             删除标签:git tag -d tag_name


    远程协作

    git remote add origin <远程仓库>  :用origin代替远程仓库

    git remote show

    git pull : 拉取同时merge  = fetch + merge   完整命令:git pull origin srcbranch:destbranch

    git push / git push的一般形式为 git push <远程主机名> <本地分支名>  <远程分支名> 

       例如 git push origin master:refs/for/master ,即是将本地的master分支推送到远程主机origin上的对应master分支, origin 是远程主机名,第一个master是本地分支名,第二个master是远程分支名。

         git push origin master : 如果远程分支被省略,如上则表示将本地分支推送到与之存在追踪关系的远程分支(通常两者同名),如果该远程分支不存在,则会被新建

             git push origin :refs/for/master  如果省略本地分支名,则表示删除指定的远程分支,因为这等同于推送一个空的本地分支到远程分支,等同于 git push origin --delete master

             git push origin : 如果当前分支与远程分支存在追踪关系,则本地分支和远程分支都可以省略,将当前分支推送到origin主机的对应分支

           git push :如果当前分支只有一个远程分支,那么主机名都可以省略,形如 git push,可以使用git branch -r ,查看远程的分支名

           git push 的其他命令

        这几个常见的用法已足以满足我们日常开发的使用了,还有几个扩展的用法,如下:

        (1) git push -u origin master : (相当于做关联)如果当前分支与多个主机存在追踪关系,则可以使用 -u 参数指定一个默认主机,这样后面就可以不加任何参数使用git push,

          不带任何参数的git push,默认只推送当前分支,这叫做simple方式,还有一种matching方式,会推送所有有对应的远程分支的本地分支, Git 2.0之前默认使用matching,现在改为simple方式

          如果想更改设置,可以使用git config命令。git config --global push.default matching OR git config --global push.default simple;可以使用git config -l 查看配置

        (2) git push --all origin : 当遇到这种情况就是不管是否存在对应的远程分支,将本地的所有分支都推送到远程主机,这时需要 -all 选项

        (3) git push --force origin :git push的时候需要本地先git pull更新到跟服务器版本一致,如果本地版本库比远程服务器上的低,那么一般会提示你git pull更新,如果一定要提交,那么可以使用这个命令。

        (4) git push origin --tags :git push 的时候不会推送分支,如果一定要推送标签的话那么可以使用这个命令

  • 相关阅读:
    玩游戏(dfs)
    Find them, Catch them(并查集)
    Shredding Company(dfs)
    Sudoku(dfs)
    Network Saboteur(dfs)
    棋盘问题(dfs)
    Curling 2.0(dfs)
    A Knight's Journey(dfs)
    15. 3Sum
    12. Integer to Roman
  • 原文地址:https://www.cnblogs.com/zzuuoo666/p/12603612.html
Copyright © 2020-2023  润新知