Git的一些用法(下)

(4) 提交分支

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

[plain] view plaincopy

  1. git push origin experiment

(5) 分支合并移除

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

[plain] view plaincopy

  1. git merge branch1

合并结果 :

[plain] view plaincopy

  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) 删除分支

删除分支命令 :

[plain] view plaincopy

  1. git branch -d branch1

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

[plain] view plaincopy

  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中检出项目源码 : 注意, 检出的源码是根目录源码, 我们在总仓库的根目录检出即可,不同再为项目创建目录;

[plain] view plaincopy

  1. git clone [email protected]:han1202012/AndroidPictureViewer.git

-- 检出克隆结果 :

[plain] view plaincopy

  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中去;

[plain] view plaincopy

  1. rm -rf bin gen

-- 查看删除结果状态 :

[plain] view plaincopy

  1. git status

-- 结果 :

[plain] view plaincopy

  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

提交缓存 :

[plain] view plaincopy

  1. git commit -a

-- 提交结果 :

[plain] view plaincopy

  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> 协作开发示例

与远程仓库同步 :

[plain] view plaincopy

  1. git pull

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

[plain] view plaincopy

  1. Already up-to-date.

修改文件后查看变更 :

[plain] view plaincopy

  1. git status

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

[plain] view plaincopy

  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 ‘‘, 提交删除 或则 改变 到本地缓存;

提交项目源码到服务器 :

[plain] view plaincopy

  1. git push

-- 提交源码结果 :

[plain] view plaincopy

  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 [email protected]:han1202012/AndroidPictureViewer.git
  16. 1ddf8c7..e4377ba  master -> master

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

时间: 2024-08-30 17:57:05

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

【git】Git branch &amp;&amp; Git checkout常见用法

git branch 和 git checkout经常在一起使用,所以在此将它们合在一起 1.Git branch 一般用于分支的操作,比如创建分支,查看分支等等, 1.1 git branch 不带参数:列出本地已经存在的分支,并且在当前分支的前面用"*"标记 1.2 git branch -r 查看远程版本库分支列表 1.3 git branch -a 查看所有分支列表,包括本地和远程 1.4 git branch dev 创建名为dev的分支,创建分支时需要是最新的环境,创建分支

Git在windows环境下的使用教程

前言 安装 配置 关于git使用的几个问题 后记 关于代码托管,以前用过vss和svn,看博客或论坛的时候,经常有人提到github,有很多著名的开源软件都托管在github,想来肯定不错(莫笑),当然我使用git并不是它有多么的出名,最主要的还是git免费,想想现在百度开发者平台都好像开始试收费了,果断休了度娘迎娶git,随时随地check自己的代码,想想是多么美妙的一件事啊. 自己动手,丰衣足食,Let's..... 安装 在使用git之前,当然要去github官网注册账号,windows环

深入学习:Windows下Git入门教程(下)

声明:由于本人对于Git的学习还处于摸索阶段,对有些概念的理解或许只是我断章取义,有曲解误导的地方还请见谅指正! 一.分支 1.1分支的概念. 对于的分支的理解,我们可以用模块化这个词来解释:在日常工作中,一个项目的开发模式往往是模块化,团队协作式的开发.这样我们项目的进度可以称得上多核并发式的开发了.这种模块化的开发要求我们尽可能的高内聚低耦合以免造成一只胳膊没了整个人都废了的局面.因此在所有的版本控制器对代码进行管理的时候都引入了分支这个概念.那么分支是什么呢? 分支是相对于主干来说的,或者

git diff的用法

git diff的用法 在git提交环节,存在三大部分:working tree, index file, commit 这三大部分中:working tree:就是你所工作在的目录,每当你在代码中进行了修改,working tree的状态就改变了.index file:是索引文件,它是连接working tree和commit的桥梁,每当我们使用git-add命令来登记后,index file的内容就改变了,此时index file就和working tree同步了.commit:是最后的阶段

Git使用教程(下)

Git使用教程(下) Git使用教程(下) 标签管理 创建标签 操作标签 删除关联的远程仓库 自定义Git 配置别名 配置文件 标签管理 发布一个版本时,我们通常先在版本库中打一个标签(tag),这样,就唯一确定了打标签时刻的版本.将来无论什么时候,取某个标签的版本,就是把那个打标签的时刻的历史版本取出来.所以,标签也是版本库的一个快照. Git的标签虽然是版本库的快照,但其实它就是指向某个commit的指针,所以,创建和删除标签都是瞬间完成的. 创建标签 打标签步骤: 首先,切换到需要打标签的

git 的基本用法

安装好git之后,在开始菜单输入:git bash, 运行. 1.新建一个仓库: git config --global user.name Chxxxxxen git config --global user.email [email protected] cd d: mkdir myGit   (这是创建一个新的文件夹) cd myGit git init 此时myGit就是你的仓库啦!备注:有下划线的都是自选的,不需要跟我写的相同. 2.使用git(本地使用),这一步是建立在已经完成了第1

Git log高级用法

格式化Log输出 首先,这篇文章会展示几种git log格式化输出的例子.大多数例子只是通过标记向git log请求或多或少的信息. 如果你不喜欢默认的git log格式,你可以用git config的别名功能来给你想要的格式创建一个快捷方式. Oneline --oneline标记把每一个提交压缩到了一行中.它默认只显示提交ID和提交信息的第一行.git log --oneline的输出一般是这样的: 0e25143 Merge branch 'feature' ad8621a Fix a b

Git stash 常见用法

Git stash git stash这个命令可以将当前的工作状态保存到git栈,在需要的时候再恢复 1.1 git stash  保存当前的工作区与暂存区的状态,把当前的工作隐藏起来,等以后需要的时候再恢复,git stash 这个命令可以多次使用,每次使用都会新加一个[email protected]{num},num是编号 1.2 git stash pop 默认恢复git栈中最新的一个[email protected]{num},建议在git栈中只有一条的时候使用,以免混乱 1.3 gi

git log 高级用法

转自:https://github.com/geeeeeeeeek/git-recipes/wiki/5.3-Git-log%E9%AB%98%E7%BA%A7%E7%94%A8%E6%B3%95 内容很详细.实用. 这是一篇在原文(BY atlassian)基础上演绎的译文.除非另行注明,页面上所有内容采用知识共享-署名(CC BY 2.5 AU)协议共享. 每一个版本控制系统的出现都是为了让你记录代码的变化.你可以看到项目的历史记录--谁贡献了什么.bug是什么时候引入的,还可以撤回有问题的