zoukankan      html  css  js  c++  java
  • git 学习笔记 window操作系统

    一.准备工作

    1.设置好操作者和邮箱

    $ git config --global user.name "Your Name"
    
    $ git config --global user.email "email@example.com"

    注意git config命令的--global参数,用了这个参数,表示你这台机器上所有的Git仓库都会使用这个配置,当然也可以对某个仓库指定不同的用户名和Email地址。

    二.git 命令大全


    1.基本命令
    mkdir创建一个目录 cd ~进入该目录 git init将该目录变成git可以管理的仓库,并添加一个.git库 ls –ah将仓库变成可见 $ls列出当前目录下所有文件

     2.命令详解

    git commit –m”” 提交改变说明,并将在暂存区的文件提交到分支上。一次也可以提交多个修改。

    git log查看历史提交记录

    git log --graph命令可以看到分支合并图。

    cat ~ 查看文件内容

    git diff HEAD -- readme.txt命令可以查看工作区和版本库里面最新版本的区别。

    $ git reset --hard HEAD^回退到上一个版本

    $ git reset --hard 1094a回退到1094a这个版本

    git reflog用来记录你的每一次命令

    HEAD指向的版本就是当前版本,因此,Git允许我们在版本的历史之间穿梭,使用命令git reset --hard commit_id

      • git log可以查看提交历史,以便确定要回退到哪个版本。
      • git reflog查看命令历史,以便确定要回到未来的哪个版本
      • git status查看一下工作区状态。
      • git checkout -- file可以丢弃工作区的修改:
        • $ git checkout -- readme.txt
        • 命令git checkout -- readme.txt意思就是,把readme.txt文件在工作区的修改全部撤销,这里有两种情况:
        • 一种是readme.txt自修改后还没有被放到暂存区,现在,撤销修改就回到和版本库一模一样的状态;
        • 一种是readme.txt已经添加到暂存区后,又作了修改,现在,撤销修改就回到添加到暂存区后的状态。
        • 总之,就是让这个文件回到最近一次git commit或git add时的状态。
        • 场景1:当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令git checkout -- file。
        •  
        • 场景2:当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令git reset HEAD <file>,就回到了场景1,第二步按场景1操作。
        • 一般情况下,你通常直接在文件管理器中把没用的文件删了,或者用rm命令删了:
      • $ rm test.txt         

    本库中删除该文件,那就用命令git rm删掉,并且git commit.

    git checkout其实是用版本库里的版本替换工作区的版本,无论工作区是修改还是删除,都可以“一键还原”。

    !!!!!另一种情况是删错了,因为版本库里还有呢,所以可以很轻松地把误删> 的文件恢复到最新版本:

    $ git checkout -- test.txt

    因为使用了git rm test.txt,是同时删除了工作区的test.txt文件,并且将删除的动作提交到了暂存区。

    git checkout -- test.txt 表示从暂存区中把test.txt拎出来,覆盖到工作区。但是,此时暂存区也已经没有了test.txt,是无法还原覆盖到工作区的。

    正确的做法是 git checkout HEAD -- d1.txt 或 git checkout HEAD d1.txt

    !!!!!这一步操作之前要确保本地仓库有文件,不能为空,否则会报错

    (error: src refspec master does not match any.

    error: failed to push some refs to 'git@github.com:wan)

    $ git remote add origin git@github.com:michaelliao/learngit.git

    从现在起,只要本地作了提交,就可以通过命令:

    $ git push origin master

     

    git remote add origin git@server-name:path/repo-name.git;关联一个远程库

    git push -u origin master第一次推送master分支的所有内容;

    git push origin master推送最新修改;

    小结

    要克隆一个仓库,首先必须知道仓库的地址,然后使用git clone命令克隆。

    Git支持多种协议,包括https,但通过ssh支持的原生git协议速度最快。

     

    查看分支:git branch

    创建分支:git branch <name>

    切换分支:git checkout <name>

    创建+切换分支:git checkout -b <name>

    合并某分支到当前分支:git merge <name>

    删除被合并后的分支:git branch -d <name>

    强制删除分支用于未被合并的分支:git branch –D <name>

     

     

    准备合并dev分支,请注意--no-ff参数,表示禁用Fast forward:

    $ git merge --no-ff -m "merge with no-ff" dev

    开发一个新feature,最好新建一个分支;

    如果要丢弃一个没有被合并过的分支,可以通过git branch -D <name>强行删除。

    stash功能,可以把当前工作现场“储藏”起来,等以后恢复现场后继续工作

    刚才的工作现场存到哪去了?用git stash list命令看看

    一是用git stash apply恢复,但是恢复后,stash内容并不删除,你需要用git stash drop来删除;

    另一种方式是用git stash pop,恢复的同时把stash内容也删了

    恢复的时候,先用git stash list查看,然后恢复指定的stash,用命令:

    $ git stash apply stash@{0}

    推送分支,就是把该分支上的所有本地提交推送到远程库。推送时,要指定本地分支,这样,Git就会把该分支推送到远程库对应的远程分支上:

    $ git push origin master

    如果要推送其他分支,比如dev,就改成:

    $ git push origin dev

    多人协作的工作模式通常是这样:

      1. 首先,可以试图用git push origin <branch-name>推送自己的修改;
      2. 如果推送失败,则因为远程分支比你的本地更新,需要先用git pull试图合并;
      3. 如果合并有冲突,则解决冲突,并在本地提交;
      4. 没有冲突或者解决掉冲突后,再用git push origin <branch-name>推送就能成功!

    如果git pull提示no tracking information,则说明本地分支和远程分支的链接关系没有创建,用命令git branch --set-upstream-to <branch-name> origin/<branch-name>

    这就是多人协作的工作模式,一旦熟悉了,就非常简单。

      • 查看远程库信息,使用git remote -v
      • 本地新建的分支如果不推送到远程,对其他人就是不可见的;
      • 从本地推送分支,使用git push origin branch-name,如果推送失败,先用git pull抓取远程的新提交;
      • 在本地创建和远程分支对应的分支,使用git checkout -b branch-name origin/branch-name,本地和远程分支的名称最好一致;
      • 建立本地分支和远程分支的关联,使用git branch --set-upstream branch-name origin/branch-name
      • 从远程抓取分支,使用git pull,如果有冲突,要先处理冲突。
      • 命令git tag <tagname>用于新建一个标签,默认为HEAD,也可以指定一个commit id;
      • 命令git tag -a <tagname> -m "blablabla..."可以指定标签信息;
      • 命令git tag可以查看所有标签。
      • 命令git push origin <tagname>可以推送一个本地标签;
      • 命令git push origin --tags可以推送全部未推送过的本地标签;
      • 命令git tag -d <tagname>可以删除一个本地标签;
      • 命令git push origin :refs/tags/<tagname>可以删除一个远程标签。

     

      

  • 相关阅读:
    Selenium(一):元素定位
    白盒测试系列(五)条件组合覆盖
    LDAP(轻型目录访问协议)
    Spring Intorduce、History and Design Philosophy
    CORS
    mysql创建用户并授权某个数据库
    Introduce Servlet 、Filter
    web.xml的简单解释以及Hello1中web.xml的简单分析
    ANNOTATION and analyse hello1.java
    Analysis of container and Injection in Java, their history and future.
  • 原文地址:https://www.cnblogs.com/wangliuyong/p/9140223.html
Copyright © 2011-2022 走看看