1. 配置ssh

    • 打开命令行或者git bash
    • 输入
  2. 创建git库

    git init
  • 检查当前状态
    $ git status
    On branch master
    nothing to commit, working directory clean

working directory clean表示当前工作目录没有未被追踪或者已修改的文件,否则会将它们列出。这个命令会告诉我们当前在哪个分支。

在当前目录会生成一个.git文件夹

  1. 远程仓库
  • 添加远程仓库

    在GitHub或者码云上创建好仓库后,复制远程仓库的HTTPS地址或ssh地址,在本地文件夹输入:

    git remote add origin <HTTPS地址或ssh地址>

    查看远程库信息:

    git remote -v
  • 从远程仓库克隆

    git clone <HTTPS地址或ssh地址>
  • 推送修改到远程仓库

    • 暂存已修改文件:
      git  add <./特定文件名>

    . 表示当前目录,会将当前目录下修改的所有文件暂存起来;特定文件名则表示将特定文件暂存。

    • 检查已暂存以及尚未暂存的更改
      git diff

    该命令会对比目前工作目录(working directory)与暂存区域(stage area)的版本,然后显示尚未暂存的文件的变更

      git diff --cached

    上一个命令如果已经暂存了所有更改的话,就什么都不显示。而该命令可以显示已暂存的更改与最后一次commit的差异。

  • 将远程修改加载到本地仓库

    git commit -m <提交信息>
    • 跳过暂存环节,直接提交
      git commit -a -m <提交信息>
  1. 分支管理
  • 查看分支

    查看本地分支:

    git branch

    查看所有分支:

    git branch -a
  • 创建分支

    git branch <分支名>
  • 切换分支

    git checkout <分支名>

    创建并切换分支:

    git checkout -b <分支名>

    切换远程分支:

    git checkout -b <分支名> origin/<分支名>

    上面的命令作用是获取远程的分支,在本地命名并切换。

  • 合并分支

    如果要将dev分支的内容合并到master:

    git checkout master
    git merge dev

    上面的命令会丢掉分支信息,可以使用:

    git merge --no-ff dev

    它会禁用fast forward,使得日志中显示分支的merge信息。

    合并部分分支:

    git cherry-pick <commit 号>

    合并多个commit(用空格指定多个commit):

    git cherry-pick A B C D E F

    指定commit范围合并(两次版本间使用..连起来):

    git cherry-pick A..B

    这样可以从版本A(不包含)到B(包含)的版本pull到当前分支

    可以多段合并,同样用空格隔开:

    git cherry-pick A..B C..D E..F

    合并远程分支:

  • 删除分支

    git branch -d <要删除的分支名>

    强制删除:

    git branch -D <要删除的分支名>

    删除远程分支:

    git push origin :<branchName>
  • 解决冲突

    有时候提交、pull以及合并的时候会出现以下情况:

    $ git merge dev
    Auto-merging readme.md
    CONFLICT (content): Merge conflict in readme.md
    Automatic merge failed; fix conflicts and then commit the result.

    上面的信息中会标出冲突文件,打开文件会发现,冲突的地方会分别有<<<<<,======,>>>>>标记出不同分支的内容,需要手动修改这些地方,留下你觉得正确需要的修改,其它删除掉,<<<<<表示的是当前分支的内容,>>>>>表示的是要合并过来的分支的内容。

    修改完后在提交就可以了。

  • stash 操作

    stash操作可以将当前尚不需要暂存的修改隐藏起来:

    $ git stash
    Saved working directory and index state WIP on dev: cb5a443 modify the file
    HEAD is now at cb5a443 modify the file
    $ git status
    On branch dev
    nothing to commit, working directory clean

    列出隐藏起来的工作现场:

    $ git stash list
    stash@{0}: WIP on dev: cb5a443 modify the file

    恢复隐藏的工作现场

    $ git stash pop
    On branch dev
    Changes not staged for commit:
    (use "git add <file>..." to update what will be committed)
    (use "git checkout -- <file>..." to discard changes in working directory) modified: readme.md no changes added to commit (use "git add" and/or "git commit -a")
    Dropped refs/stash@{0} (5e674302787482fbdd0c3e6fb455a5aca102a9d2)

    pop命令在恢复的同时会将栈顶的stash的内容删除,调用git stash apply恢复后,stash内容并不会删除,需要调用git stash drop命令才能删除

    多次stash的话,可以先调用git stash list查看stash列表,然后调用git stash apply stash@{},这里的num指的是在stash栈中的index。

  • 推送修改到远程分支

    git add .
    git commit -m "..."
    git push origin <branchName>
  • 获取远程修改的几种方式

    git pull

    这个操作包含了fetch和merge,会创建多个临时分支,不是很好,可以这样:

    git pull --rebase

    当出现冲突时会:

    $ git pull --rebase origin dev
    From https://github.com/liberty2015/gitdemo
    * branch dev -> FETCH_HEAD
    First, rewinding head to replay your work on top of it...
    Applying: update the file
    Using index info to reconstruct a base tree...
    M readme.md
    Falling back to patching base and 3-way merge...
    Auto-merging readme.md
    CONFLICT (content): Merge conflict in readme.md
    error: Failed to merge in the changes.
    Patch failed at 0001 update the file
    The copy of the patch that failed is found in: .git/rebase-apply/patch When you have resolved this problem, run "git rebase --continue".
    If you prefer to skip this patch, run "git rebase --skip" instead.
    To check out the original branch and stop rebasing, run "git rebase --abort".

    当解决完冲突后:

    git rebase --continue

    或者跳过:

    git rebase --skip
  1. 标签管理

  2. 日志查询

    git log -<num>

    查询日志,num表示查询日志数量

    图形工具查询方式:

    gitk

参考网址:

https://ihower.tw/blog/archives/3843

https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/001375840202368c74be33fbd884e71b570f2cc3c0d1dcf000

http://hungyuhei.github.io/2012/08/07/better-git-commit-graph-using-pull---rebase-and-merge---no-ff.html

https://kingofamani.gitbooks.io/git-teach/content/chapter_2/repo.html

git 基础学习笔记的更多相关文章

  1. 【C#编程基础学习笔记】4---Convert类型转换

    2013/7/24 技术qq交流群:JavaDream:251572072  教程下载,在线交流:创梦IT社区:www.credream.com [C#编程基础学习笔记]4---Convert类型转换 ...

  2. 【C#编程基础学习笔记】6---变量的命名

    2013/7/24 技术qq交流群:JavaDream:251572072  教程下载,在线交流:创梦IT社区:www.credream.com [C#编程基础学习笔记]6---变量的命名 ----- ...

  3. 1.C#基础学习笔记3---C#字符串(转义符和内存存储无关)

    技术qq交流群:JavaDream:251572072  教程下载,在线交流:创梦IT社区:www.credream.com ------------------------------------- ...

  4. Java基础学习笔记总结

    Java基础学习笔记一 Java介绍 Java基础学习笔记二 Java基础语法之变量.数据类型 Java基础学习笔记三 Java基础语法之流程控制语句.循环 Java基础学习笔记四 Java基础语法之 ...

  5. git的学习笔记(二):git远程操作

    1.创建ssh key ssh-keygen -t rsa -C "your_email@example.com" 执行命令后会在用户的家目录生成.ssh的隐藏文件夹,文件夹里有公 ...

  6. Mysql数据库基础学习笔记

    Mysql数据库基础学习笔记 1.mysql查看当前登录的账户名以及数据库 一.单表查询 1.创建数据库yuzly,创建表fruits 创建表 ) ) ,) NOT NULL,PRIMARY KEY( ...

  7. 0003.5-20180422-自动化第四章-python基础学习笔记--脚本

    0003.5-20180422-自动化第四章-python基础学习笔记--脚本 1-shopping """ v = [ {"name": " ...

  8. Java基础学习笔记(一)

    Java基础学习笔记(一) Hello World 基础代码学习 代码编写基础结构 class :类,一个类即一个java代码,形成一个class文件,写于每个代码的前端(注意无大写字母) XxxYy ...

  9. C#RabbitMQ基础学习笔记

    RabbitMQ基础学习笔记(C#代码示例) 一.定义: MQ是MessageQueue,消息队列的简称(是流行的开源消息队列系统,利用erlang语言开发).MQ是一种应用程序对应用程序的通信方法. ...

随机推荐

  1. 浏览器输入url的全过程

    ########################################################################### ######################## ...

  2. 32Sql数据库的插入

    上一节讲了数据库的连接,本例直接将数据库的插入操作,重点还是QSqlQuery类 QSqlQuery query; //新建二维表 query.exec("CREATE TABLE stud ...

  3. MapReduce: number of mappers/reducers

    14 down vote It's the other way round. Number of mappers is decided based on the number of splits. I ...

  4. oracle中 start with .. connect by prior.. 用法简介

    我们经常会将一个比较复杂的目录树存储到一个表中.或者将一些部门存储到一个表中,而这些部门互相有隶属关系.这个时候你就会用到connect by prior start with.oracle 提供了s ...

  5. PostgreSQL 9.3:在windows(包括win7)下的安装与正确配置

    首先,以下是常用命令: ③ initdb 初始化 数据库. ④ pg_ctl start 启动数据库 ⑤ pg_ctl stop 停止数据库 ⑥ post_svc -install 建立windows ...

  6. mongodb的分片

    分片是把大型数据集合进行分区成更小的可管理的片的过程. 副本集的每一个成员(仲裁节点除外)都一份数据的完整拷贝! 分片的目的:在节省硬件成本的基础上,提高系统的整体性能.但是却增加了管理和性能的开销. ...

  7. 五,动态库(dll)的封装与使用

    在项目开发中,我们经常会使用到动态库(dll),要么是使用别人的动态库,要么是将功能函数封装为动态库给别人用.那么如何封装和使用动态库呢?以下内容为你讲解. 1.动态库的封装 以vs2010为例,我们 ...

  8. 20162314 Experiment 3 - Sorting and Searching

    Experiment report of Besti course:<Program Design & Data Structures> Class: 1623 Student N ...

  9. Dekker算法在多核处理器下的失效

    Dekker algorithm是一种著名的并发编程的算法,Dekker算法的核心部分是一组对称的代码来访问一组共享变量,使得两个线程不可能同时进入临界区(只要cpu内存模型是遵循顺序一致性的),从而 ...

  10. linux下查看当前登陆的用户数目

    在shell下输入以下语句即可获取: who | awk '{print $1}' | sort | uniq | wc -l