一、常用操作命令

1、初始化操作

git config --global user.name '<name>'           # 设置提交者名称
git config --global user.email '<email>'         # 设置提交者邮箱
git config --list                       # 查看以后配置

2、创建版本库

git clone <url>                        # 克隆 远程仓库
git init                            # 初始化本地库

3、创建删除分支

git checkout -b <branch>                    # 创建并切换至新的分支
git checkout -b <branch> <origin/branch>          # 将远程origin/branch分支 拉到本地 branch分支,并切换到branch 分支
git checkout <branch>                      # 切换分支
git branch <branch> # 创建新分支
git branch -a                           # 查看所有分支 包括远程分支
git branch                            # 查看本地分支
git branch -D                          # 强制删除本地分支(慎用)
git branch -d                          # 删除本地分支
git branch -r -d <remote>/<branch> # 删除远程分支

4、创建标签

git tag                            #列出所有的标签
git tag <tagname>                      #创建新的标签
git tag -d <tagname>                    #删除标签

5、提交及修改

git add .                     # 提交所有文件至暂存区
git add <file>   # 提交单个文件至暂存区
git rm -f <file>   # 删除暂存区文件 和 物理文件
git rm --cached <file>     # 删除暂存区文件 回到工作区
git commit -m '<注释>'      # 提交至本地分支 并注释
git reset --hard HEAD^              # 撤回至上一次提交,之前的提交文件都会丢失

6、合并

git merge <branch>                         # 合并分支

7、远程操作

git pull <remote> <branch>           # 拉取远程分支代码
git push <remote> <branch>           # 提交分支代码
git push -d <remote/banch>           # 删除远程分支
git push <remote> :<branch>          # 删除远程分支 需配合 git branch -r -d <remote>/<branch> 一起使用
git push -tag                   # 提交所有 标签

8、藏存

git stash                      # 将当前修改存储
git stash pop                    # 将存储释放

9、远程地址操作

git remote -v                                      # 查看远程仓库地址
git remote rename origin origin-old       # 修改远程仓库地址origin 改为origin-old
git remote add origin [url] # 添加远程地址origin
git remote origin set-url [url] # 将origin 的远程仓库地址变更

10、修改分支,并删除远程旧分支,提交新分支

// 本地 旧分支oldbranch  改成新分支 newbranch
git branch -m oldbranch newbranch // 删除远程仓库内的旧分支oldbranch
git push --delete origin oldbranch // 提交新分支至远程仓库
git push origin newbranch

二、简单git操作

1、拉取代码(该操作只需要一次)

git clone <url>

2、拉取最新代码

git pull

3、切换新的分支

git checkout -b <branch>                          # 与git branch <branch>   然后 git checkout <branch>     两步操作的结果是一样的  

4、合并别人的分支尽心开发(如果你的这次任务需要合并别人的分支,进行开发则进行如下操作,不需要请跳过)

git merge <remote>/<branch>                       # 合并 某分支代码
git add .                         # 将其提交至暂存区
git commit - m '已合并XXX分支代码'           # 提交至自己当前分支

5、自己的任务修改完后,将代码从你自己本地的工作区提交至暂存区

git add .                                         # 提交所有的代码至暂存区

6、撤回暂存区提交的多余的修改文件(不需要撤回请跳过)

git rm -cached <file>                             # 撤回暂存区提交的多余文件

7、将暂存区代码提交至当前分支

git commit  -m '<注释>'

8、将当前分支提交至远程库

git push <remote>/<branch>                               # 如果你的分支是test  那么就 git push origin/test

9、切回master 分支,再次拉取最新代码进行下一次开发

git checkout <branch>                               # 切回至主分支,一般是master 分支
git pull                           # 拉取最新的代码    
git checkout -b <branch>                 # 创建并切换到一个新的分支,开始下一个任务的开发 。。。。。如此循环的

三、github参与他人项目的开发

1、进入原作者的github 项目,点击frok 参与。

  

2、此时进入自己的github,我会发现多了一个与原作者相同的项目。

  

3、此时从你的这个项目中clone到你本地修改提交后。再去点击New pull request

  

4、此时你会看到你之前修改提交上来的内容,点击create pull request 将你的修改提交给原作者

  

  

5、原作者看到后,会自行决定,合并与否。下面的原作者的github

  原作者点击pull request 

  

  原作者点击是否合并参与者的内容

  

  原作者确定合并

  

6、参与人如何保持与原作者的项目更新

  进入参与者自己的github项目中点击 New pull request

  

  选择compare across forks 。反向操作。base  fork改为自己的,head fork改为原作者的。

  

  合并 拉取最新

  

git 使用方式的更多相关文章

  1. git http方式时保存密码

    一直使用ssh方式,但是git@osc的ssh只能pull,不能push  - -|||    htts方式保存密码老是忘记,每次提交代码都要输入密码烦死了.找到文章备忘: 转自:http://git ...

  2. Git认证方式https和ssh的原理及比较

    常见的代码托管平台GitHub.GitLab和BitBucket等,基本都会使用Git作为版本控制工具.平台一般都提供两种认证方式https和ssh.了解该过程能够更加自由的配置和使用,本文就来简单聊 ...

  3. 超实用 Git 使用方式介绍

    都说程序员若是不知道 GitHub 就不是一个合格的程序员,其实这话说的过分了,不知道就学嘛,今天我们就来说说 Git 和 GitHub 到底是什么. 我们在开发软件的时候,常常是需要多人协作完成,这 ...

  4. jenkins之配置git认证方式

    在使用jenkins构建时候需要从git下拉代码,需要配置认证方式 http拉取代码 配置用户名和密码认证 添加认证 设置用户名和密码 git认证 设置私钥认证

  5. Git上手:四种常见的Git协同工作方式

    1.集中式工作流 适用人群:开发小团队(4-5人),习惯使用SVN工具的小团队. 工作方式:团队组长创建远程仓库,创建一个master分支,组员可读可写. 每个开发人员都git clone远程仓库到本 ...

  6. git rebase VS git merge? 更优雅的 git 合并方式值得拥有

    写在前面 如果你不能很好的应用 Git,那么这里为你提供一个非常棒的 Git 在线练习工具 Git Online ,你可以更直观的看到你所使用的命令会产生什么效果 另外,你在使用 Git 合并分支时只 ...

  7. git reflog 和git log :no branch git 提交方式

    git reflog 和git log的区别,外加git cherry-pick的一种用法 git reflog 可以查看所有分支的所有操作记录(包括(包括commit和reset的操作),包括已经被 ...

  8. builtroot 添加git 下载方式

    1.buildroot/Config.in 配置default git server eg:config xxxx_GIT_SITE string "git site" defau ...

  9. Git HTTPS 方式自动保存用户名密码

    一行命令搞定: git config --global credential.helper wincred 第一次输入用户名和密码提交,第二次就不需要了 参考: https://help.github ...

随机推荐

  1. KV型内存数据库Redis

    Redis是开源的高性能内存Key-Value数据库, 可以提供事务和持久化支持, 并提供了TTL(time to life)服务. Redis采用单线程数据操作+非阻塞IO的模型,非阻塞IO提供了较 ...

  2. 原生javascript 的MAP使用

    var map = {}; // Map map = new HashMap();map[key] = value; // map.put(key, value);var value = map[ke ...

  3. vue项目中遇到的问题

    在 export defaul new Router({ )} 这个路由配置中一定要加mode : 'history' 否者就会在路由前面默认添加# 路由跳转的几种方式: 在VUE中使用less来编译 ...

  4. Django2.0文档

    第四章 模板 1.标签 (1)if/else {% if %} 标签检查(evaluate)一个变量,如果这个变量为真(即,变量存在,非空,不是布尔值假),系统会显示在 {% if %} 和 {% e ...

  5. 用dd实现linux硬盘备份

    一个去年的老本,500G硬盘,空间各种捉急,准备迁移到公司的台式机上,却发现Linux上迁移环境没有Windows下那么方便,只能复制整块硬盘了. 从公司拿了一块1T的硬盘,插入移动硬盘盒(淘宝上搞的 ...

  6. Java报SQLException

    Java报SQLException 具体错误如下: java.sql.SQLException:Column count doesn't match value count at row 1

  7. My97 DatePicker普通调用

    My97 DatePicker普通调用 1.设计源码 <%@ page language="java" import="java.util.*" page ...

  8. Java注释分类

    Java注释分类 1.单行注释    //打印结果    System.out.println("结果是:"+result); 2.多行注释    /**     * @autho ...

  9. Flex中对表格中某列的值进行数字格式化

    1.问题背景 一般的,表格中展示的比率,对比率的处理是:保留两位小数,并向上保留 2.实现实例 <?xml version="1.0" encoding="utf- ...

  10. python实现简单排序算法

    算法 递归两个特点: 调用自身 有穷调用 计算规模越来越小,直至最后结束 用装饰器修饰一个递归函数时会出现问题,这个问题产生的原因是递归的函数也不停的使用装饰器.解决方法是,只让装饰器调用一次即可,那 ...