美文网首页
2.git学习系列之git基本操作和分支管理

2.git学习系列之git基本操作和分支管理

作者: 小manong | 来源:发表于2018-09-16 17:20 被阅读0次

    一、git基本操作

    1、git的结构

    • git工作结构分为三个区域:工作区、临时存储区、本地库,三者之间的关系如图所示(写代码是在工作区完成-->add-->临时存储区stage-->commit-->本地仓库)


      git结构

    2、git基本命令

    (1)创建本地版本库

    git init命令是初始化本地仓库

    • 先打开Git Bash命令行界面:
    Administrator@BF-20180604CDXI MINGW64 ~/Desktop
    $ mkdir demo
    Administrator@BF-20180604CDXI MINGW64 ~/Desktop
    $ cd demo
    Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo
    $ pwd
    /c/Users/Administrator/Desktop/demo
    Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo
    $ git init//初始化本地仓库
    Initialized empty Git repository in C:/Users/Administrator/Desktop/demo/.git/
    Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
    $ ll -a//查看本地仓库目录下文件,.git/为隐藏文件
    total 20
    drwxr-xr-x 1 Administrator 197121 0 九月 15 23:47 ./
    drwxr-xr-x 1 Administrator 197121 0 九月 15 23:47 ../
    drwxr-xr-x 1 Administrator 197121 0 九月 15 23:47 .git/
    

    (2)提交文件到本地仓库

    git add把写好的代码从工作区提交到临时存储区stage
    git commit 把临时区的代码提交到本地仓库
    git status 查看状态(工作区,临时区的状态)
    git log查看历史提交版本
    git log --oneline整洁的查看历史提交版本
    git reflog可以查看所有分支的所有操作记录

    Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
    $ vim demo//1、在工作区中创建一个文件
    Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
    $ git status//2、查看状态(此刻还在工作区中)
    On branch master
    No commits yet
    Untracked files:
      (use "git add <file>..." to include in what will be committed)
            demo
    nothing added to commit but untracked files present (use "git add" to track)
    Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
    $ git add ..//3、从工作区添加到临时区
    warning: LF will be replaced by CRLF in demo.
    The file will have its original line endings in your working directory.
    Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
    $ git status//4.查看状态(此时在临时区了)
    On branch master
    No commits yet
    Changes to be committed:
      (use "git rm --cached <file>..." to unstage)
            new file:   demo
    Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
    $ git log//5、查看历史提交记录(此时没有历史提交记录)
    fatal: your current branch 'master' does not have any commits yet
    Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
    $ git commit -m "demo"//6、提交代码到本地仓库
    [master (root-commit) fed3895] demo
     1 file changed, 1 insertion(+)
     create mode 100644 demo
    Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
    $ git status//7、查看状态(此时在本地仓库了)
    On branch master
    nothing to commit, working tree clean
    Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
    $ git log//8、查看历史提交记录(此时有一条记录commitid=fed3895exxx)
    commit fed3895eef27f31ec8a0b0642223e5742bb22d02 (HEAD -> master)
    Author: qiuzhangwei <2608442616@qq.com>
    Date:   Sun Sep 16 00:02:33 2018 +0800
        demo
    Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
    $ git reflog//9、整洁的查看历史
    fed3895 (HEAD -> master) HEAD@{0}: commit (initial): demo
    Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
    $
    

    (3)回退修改(回退modified文件)

    • 修改后,还没有add到临时区

    git checkout -- 文件(放弃改变在工作区)

    • add到临时区但是没有commit到本地仓库

    先git reset HEAD 文件(从暂存区回到工作区)
    然后git checkout -- 文件(放弃改变在工作区)

    • 已近commit到了本地仓库

    git reset --hard 版本号或HEAD^或HEAD~n(本地仓库回退到之前的版本)

    (4)其他基本操作

    git status 状态查看(工作区、暂存区状态)
    git log查看历史记录
    git reflog查看简介的历史记录
    git diff 比较文件差异(将工作区中的文件和暂存区进行比较)

    3.分支管理

    (1)概念

    在版本控制过程中,使用多条线同时推进多个任务。

    (2)分支好处

    • 同时并行推进多个功能开发,提高开发效率
    • 各个分支在开发过程中,如果某一个分支开发失败,不会对其他分支有任何影响。失败的分支删除重新开始即可

    (3)分支基本操作

    git branch [分支名]创建分支
    git branch -v查看分支
    git checkout [分支名]切换分支
    git branch -d [分支名]删除未提交的分支
    git branch -D [分支名]强制删除一个已经提交了的分支

    Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
    $ git branch -v//查看当前分支
    * master f302b1c sdf
    Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
    $ git branch dev//创建dev分支
    Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (master)
    $ git checkout dev//切换到dev分支
    Switched to branch 'dev'
    Administrator@BF-20180604CDXI MINGW64 ~/Desktop/demo (dev)
    $ git branch -v//查看当前分支
    * dev    f302b1c sdf
      master f302b1c sdf
    

    (4)使用merge分支合并


    merge流程图

    第一步:切换到接受修改的分支(被合并,增加新内容)上
    git checkout [被合并分支名]
    第二步:执行 merge 命令
    git merge [有新内容分支名]
    第三步:解决冲突如果有冲突的话
    -->打开冲突文件
    -->把文件修改到满意的程度,保存退出
    -->git add [文件名]
    -->git commit -m "日志信息"

    案例:

    在master分支上
    1、vim a.txt
    a1
    2、git add和git commit提交到本地仓库
    切换到dev分支
    3、git checkout dev
    4、vim a.txt
    a2
    5、git add和git commit提交到本地仓库
    切换回master分支进行合并
    6、git merge dev--产生冲突
    7、vim a.txt进行冲突解决
    ----------------------------当前分支内容--------------------------
    <<<<<<< HEAD
    a1
    =======
    ----------------------------需要合并的分支内容--------------------------
    a2
    >>>>>>> dev
    8、解决冲突后vim a.txt
    a1
    a2
    9、进行git add 和git commit就完成了分支的合并
    

    (5)使用rebase合并分支

    第一步:切换到接受修改的分支(被合并,增加新内容)上
    git checkout [被合并分支名]比如develop
    第二步:执行 rebase命令
    git rebase[有新内容分支名]比如master
    第三步:解决冲突如果有冲突的话
    -->打开冲突文件
    -->把文件修改到满意的程度,保存退出
    -->git add [文件名]
    -->git rebase --continue
    -->推到远程仓库然后进行取出冲突
    -->如果要放弃这次合并,使用git rebase --abort
    第四步:快进式合并一下,移动 master 的指针指向最新的提交
    git merge master develop

    rebase合并流程图

    相关文章

      网友评论

          本文标题:2.git学习系列之git基本操作和分支管理

          本文链接:https://www.haomeiwen.com/subject/bxcxnftx.html