(4) 提交分支

提交分支命令 : 将本地的分支提交到 GitHub中;

  1. git push origin experiment

(5) 分支合并移除

合并分支命令 : 合并分支之后, 分支中有的文件在 主分支中也会显示, 相当于将branch1 分支中的文件拷贝了一份到master分支中;

  1. git merge branch1

合并结果 :

  1. Updating f1bb97a..7f5785e
  2. Fast-forward
  3. description_branch1.txt | 0
  4. 1 file changed, 0 insertions(+), 0 deletions(-)
  5. create mode 100644 description_branch1.txt

.

(6) 删除分支

删除分支命令 :

  1. git branch -d branch1

强制删除分支命令 : 如果branch1 分支还没有被合并的话, Git是不允许删除这个分支的, 此时要想删除该分支, 就只能使用下面的命令强制删除该分支 :

  1. git branch -D branch1

4. Git工作流程

(1) 两种工作流程

协作开发工作流程 : 这种情况是最复杂的情况, 多人团队共同开发一个项目;

-- 与远程仓库同步 : git pull ;

-- 修改文件 : 添加 删除 修改文件;

-- 查看变更 : git status ;

-- 载入变更 :添加文件, 先使用git add fileName, 在使用 git commit -m 'note' 载入变更; 如果是删除 修改文件, 直接使用 git commit -m 'note' 提交;

-- 重复 : 重复执行 修改文件 查看变更 载入变更 提交载入动作;

-- 上传 : 使用 git push 命令将项目源码提交带GitHub中去;

单独开发工作流程 : 如果是个人独立开发, 仅追踪本地文件变更, 就不需要提交到服务器上, 因为Git是分布式的;

-- 修改文件 :

-- 提交变更 :

-- 重复 :

(2) 简单示例

1> 独立开发示例

该示例不会上传, 仅在本地进行操作;

从GitHub中检出项目源码 : 注意, 检出的源码是根目录源码, 我们在总仓库的根目录检出即可,不同再为项目创建目录;

  1. git clone git@github.com:han1202012/AndroidPictureViewer.git

-- 检出克隆结果 :

  1. Cloning into 'AndroidPictureViewer'...
  2. remote: Counting objects: 86, done.
  3. remote: Compressing objects: 100% (62/62), done.
  4. remote: Total 86 (delta 3), reused 86 (delta 3)
  5. Receiving objects: 100% (86/86), 1.67 MiB | 109.00 KiB/s, done.
  6. Resolving deltas: 100% (3/3), done.
  7. Checking connectivity... done.

删除bin和gen目录 : 这两个目录是Android工程编译产生的临时文件, 没有必要上传到GitHub中去;

  1. rm -rf bin gen

-- 查看删除结果状态 :

  1. git status

-- 结果 :

  1. On branch master
  2. Your branch is up-to-date with 'origin/master'.
  3. Changes not staged for commit:
  4. (use "git add/rm <file>..." to update what will be committed)
  5. (use "git checkout -- <file>..." to discard changes in working directory)
  6. deleted:    bin/AndroidManifest.xml
  7. deleted:    bin/ImageView_Test.apk
  8. deleted:    bin/classes.dex
  9. deleted:    bin/res/crunch/drawable-xxhdpi/ic_launcher.png
  10. deleted:    bin/resources.ap_
  11. deleted:    gen/shuliang/han/imageview_test/BuildConfig.java
  12. deleted:    gen/shuliang/han/imageview_test/R.java

提交缓存 :

  1. git commit -a

-- 提交结果 :

  1. [master e4377ba] delete bin and gen directory.
  2. 28 files changed, 2 insertions(+), 110 deletions(-)
  3. create mode 100644 .gitignore
  4. delete mode 100644 bin/AndroidManifest.xml
  5. delete mode 100644 bin/ImageView_Test.apk
  6. delete mode 100644 bin/classes.dex
  7. delete mode 100644 bin/resources.ap_
  8. delete mode 100644 gen/shuliang/han/imageview_test/BuildConfig.java
  9. delete mode 100644 gen/shuliang/han/imageview_test/R.java

2> 协作开发示例

与远程仓库同步 :

  1. git pull

-- 如果其他人没有提交项目到GitHub上, 就会出现下面结果 :

  1. Already up-to-date.

修改文件后查看变更 :

  1. git status

-- 如果没有变更会出现下面情况 :

  1. On branch master
  2. Your branch is ahead of 'origin/master' by 1 commit.
  3. (use "git push" to publish your local commits)
  4. nothing to commit, working directory clean

载入变更 : 如果有变更, 那么使用命令载入变更. 使用 git commit -a 或者 git add 命令;

-- 添加文件 : 先使用 git add 文件名 来添加文件到缓存, 之后使用 git commit -m '' 命令提交代码到本地缓存;

-- 删除改变文件 : 直接使用 git commit -m '', 提交删除 或则 改变 到本地缓存;

提交项目源码到服务器 :

  1. git push

-- 提交源码结果 :

  1. warning: push.default is unset; its implicit value is changing in
  2. Git 2.0 from 'matching' to 'simple'. To squelch this message
  3. and maintain the current behavior after the default changes, use:
  4. git config --global push.default matching
  5. To squelch this message and adopt the new behavior now, use:
  6. git config --global push.default simple
  7. See 'git help config' and search for 'push.default' for further information.
  8. (the 'simple' mode was introduced in Git 1.7.11. Use the similar mode
  9. 'current' instead of 'simple' if you sometimes use older versions of Git)
  10. Counting objects: 4, done.
  11. Delta compression using up to 2 threads.
  12. Compressing objects: 100% (2/2), done.
  13. Writing objects: 100% (3/3), 292 bytes | 0 bytes/s, done.
  14. Total 3 (delta 1), reused 0 (delta 0)
  15. To git@github.com:han1202012/AndroidPictureViewer.git
  16. 1ddf8c7..e4377ba  master -> master

查看GitHub中的源码情况 : gen 和 bin 目录果然被删除了;

Git的一些用法(下)的更多相关文章

  1. Git 安装及用法 github 代码发布 gitlab私有仓库的搭建

    版本控制是一种记录一个或若干文件内容变化,以便将来查阅特定版本修订情况的系统. 这个版本控制软件,有 svn还有git,是一个工具. git是由linux的作者开发的 git是一个分布式版本控制系统 ...

  2. git clone、git pull和git fetch的用法及区别

    声明:码字不易,转载请注明出处,欢迎文章下方讨论交流.Git 常用命令速查表 最近在一个学习小组里学习AI的课程,我们所有的学习资料和homework都放在gitlab上.今天一个小队友从gitlab ...

  3. Git的一些用法

    三. Git的一些用法 1. .gitignore文件 屏蔽文件 : .gitignore文件是告诉Git哪些目录或者文件需要忽略, 这些文件将不被提交; 常用场景 : 写完代码后会执行变异调试等操作 ...

  4. git日常基本用法

    git作为项目管理现在已经是越来越广泛应用,结合自己平时的一些基本操作加上git说明文档里面的一些补充,我总结了一下git的基本用法: mkdir project # 创建项目目录 cd projec ...

  5. Git branch 和 Git checkout常见用法

    git branch 和 git checkout经常在一起使用,所以在此将它们合在一起 1.Git branch 一般用于分支的操作,比如创建分支,查看分支等等, 1.1 git branch 不带 ...

  6. Git 版本控制 在 WIN 下的一些使用方法

    这里记录一些 Git 在 Windows 操作系统下使用方法: 安装完毕后,先让Git 记录自己的名字: $ git config --global user.name "Your Name ...

  7. Eclipse Git和sourceTree用法

    Eclipse Git和sourceTree用法 Eclipse Git: 提交代码到git: 1.team->Repository->pull 若没有冲突: 2.team->com ...

  8. Git系列(1) Windows下Git服务器搭建

    作为对前两天Git服务器搭建的一个整理,我想分别从服务端和客户端两个角度来记录下整个搭建过程,为了达到目标,我们需要哪些操作. (一)服务端软件和账号的安装配置 我们这里只需要两个软件git和ssh, ...

  9. Mybatis基本用法--下

    Mybatis基本用法--下 第七部分 mybatis-spring-boot-starter 官网:http://www.mybatis.org/spring-boot-starter/mybati ...

  10. 版本控制工具——Git常用操作(下)

    本文由云+社区发表 作者:工程师小熊 摘要:上一集我们一起入门学习了git的基本概念和git常用的操作,包括提交和同步代码.使用分支.出现代码冲突的解决办法.紧急保存现场和恢复现场的操作.学会以后已经 ...

随机推荐

  1. 20-list简单使用:

    C++list的使用总结及常用list操作 C++中list用法详解 STL中list的erase()方法的使用   listiterator 最近刚刚接触stl的list    学习的时候遇到了很多 ...

  2. 冲刺NOIP2015提高组复赛模拟试题(五)1.数学作业

    1. 数学作业 [问题描述] 路人丙的数学老师非常乏力,他喜欢出一些非常乏力的数学题来为难乏力的学生们.这次数学老师布置了一堆的数学题作为作业,而且这些数学题有个共同的特点是都求C(N,M)中不同质因 ...

  3. 开源项目spring-shiro-training思维导图

    写在前面 终于完成了一个开源项目的思维导图解读.选spring-shiro-training这个项目解读是因为它开源,然后涉及到了很多我们常用的技术,如缓存,权限,任务调度,ssm框架,Druid监控 ...

  4. .NET开源MSSQL、Redis监控产品Opserver之Redis配置

    安全与基础配置地址:http://www.cnblogs.com/xiaopotian/p/6898310.html edis监控数据实例的加载可以查看Opserver.Core项目data/Redi ...

  5. Session分布式共享 = Session + Redis + Nginx(转)

    出处:http://www.cnblogs.com/newP/p/6518918.html 一.Session 1.Session 介绍 我相信,搞Web开发的对Session一定再熟悉不过了,所以我 ...

  6. CodeForces 289A Polo the Penguin and Segments (水题)

    题意:给你 n 段区间,而且还是不相交的,然后你只能向左扩展左端点,或者向右扩展右端点,然后扩展最少的步数让整数总数能够整除 k. 析:很简单么,只要在记录算一下数量,然后再算出 k 的倍数差多少就行 ...

  7. CodeForces 540B School Marks (贪心)

    题意:先给定5个数,n,  k, p, x, y.分别表示 一共有 n 个成绩,并且已经给定了 k 个,每门成绩 大于0 小于等于p,成绩总和小于等于x, 但中位数大于等于y.让你找出另外的n-k个成 ...

  8. 字节序(Endian),大端(Big-Endian),小端(Little-Endian)

    http://www.cppblog.com/tx7do/archive/2009/01/06/71276.html 在各种计算机体系结构中,对于字节.字等的存储机制有所不同,因而引发了计算机通信领域 ...

  9. log4j.properties加入内容

    log4j.rootLogger=INFO, stdout log4j.appender.stdout=org.apache.log4j.ConsoleAppender log4j.appender. ...

  10. ThinkJS 中的Logic层

    第一个为什么需要Logic层: 当在 Action 里处理用户的请求时,经常要先获取用户提交过来的数据,然后对其校验,如果校验没问题后才能进行后续的操作:当参数校验完成后,有时候还要进行权限判断等,这 ...