简单几步操作让你在终端下用git实现文件的上传。

一、克隆项目
    在工作中,常见的情景都是远程库已经建好了,需要大家把代码拉下来,共同协作开发。本文所有操作均在终端下进行。
    //克隆一个本地库
    git clone 你的远程仓库地址

二、本地库的操作
   //添加修改
    1、git add 修改的文件名
     //提交修改内容
    2、git commit -m "修改备注"

三、把修改的内容提交到远程库
    //第一次推送,加上-u参数,以后推送可省略
     git push -u origin master

就这简单几步,就能实现你的代码上传到远程仓库啦。如果你还有其他更多需求,可以继续往下看。

四、其他经常用到的操作
  1、基本操作

  //添加远程仓库

  git remote add origin 远程仓库地址

//用Xcode打开文件
     open -a Xcode 文件名

//随时掌握工作区的状态
     git status

//查看文件的修改内容
    git diff  文件名

2、版本管理
    //版本回退到上一个版本,HEAD表示最新版本
    git reset --hard HEAD^

//版本回退到上上一个版本
    git reset --hard HEAD^^

//查看提交历史,可以看到不同版本的commit_id
    git log   //出来的信息较全较多,下面的命令出来的简略点
    git log --pretty=oneline

//查看命令历史,以便确定回到未来的哪个版本
    git reflog

//版本回退到指定版本,commit_id
    git reset --hard commit_id

3、修改和删除操作
    //可以丢弃工作区的修改,-- 很重要,不能少,否则会变成“切换到另一个分支”
    git checkout -- 文件名

//把暂存区的修改撤销掉,重新放回工作区
    git reset HEAD 文件名

//删除文件
    git rm 文件名

4、分支管理
    git 推荐使用分支完成某个任务,合并后再删掉分支。这样过程更安全
     1)创建并切换到分支,-b 表示创建并切换
        git checkout -b 分支名字
        等于两条命令: git branch 分支名字     //创建分支
                    git checkout 分支名字     //切换到分支

2)列出所有分支,当前分支前面会标一个*号
        git branch

3)在分支上进行修改等操作
        git add 文件名
        git commit -m "修改备注"

4)分支工作完成,切换回master分支,把分支工作成果合并到master分支上,然后删除分支
       git checkout master
       git merge 分支名字
       git branch -d 分支名字

合并分支时,git会优先用Fast forward模式,这种模式下,删除分支后,会丢掉分支信息。
       强制禁用Fast forward模式,git就会在merge时生成一个新的commit,这样,从分支历史上就可以看出分支信息
        //--no-ff参数,表示禁用Fast forward
       git merge --no-ff -m "merge with no-ff" 分支名字

5)发生冲突的话需要手动进行修改,在提交合并
      //可以看到分支合并图
      git log --graph
   
    在实际开发中,我们应该按照几个基本原则进行分支管理:
  1、master分支应该是非常稳定的,也就是仅用来发布新版本,平时不能在上面干活
    2、那在哪干活呢?干活都在自己建的分支上
    3、你和你的小伙伴们每个人都有自己的分支,时不时地往分支上合并就可以了

git 基本使用的更多相关文章

  1. Git 子模块 - submodule

    有种情况我们经常会遇到:某个工作中的项目需要包含并使用另一个项目. 也许是第三方库,或者你 独立开发的,用于多个父项目的库. 现在问题来了:你想要把它们当做两个独立的项目,同时又想在 一个项目中使用另 ...

  2. Git 在团队中的最佳实践--如何正确使用Git Flow

    我们已经从SVN 切换到Git很多年了,现在几乎所有的项目都在使用Github管理, 本篇文章讲一下为什么使用Git, 以及如何在团队中正确使用. Git的优点 Git的优点很多,但是这里只列出我认为 ...

  3. Git与Repo入门

    版本控制 版本控制是什么已不用在说了,就是记录我们对文件.目录或工程等的修改历史,方便查看更改历史,备份以便恢复以前的版本,多人协作... 一.原始版本控制 最原始的版本控制是纯手工的版本控制:修改文 ...

  4. Git Bash的一些命令和配置

    查看git版本号: git --version 如果是第一次使用Git,你需要设置署名和邮箱: $ git config --global user.name "用户名" $ gi ...

  5. 在Ubuntu 16.10 安装 git 并上传代码至 git.oschina.net

    1. 注册一个账号和创建项目 先在git.oschina.net上注册一个账号和新建一个project ,如project name 是"myTest". 2.安装git sudo ...

  6. 史上最详细git教程

    题外话 虽然这个标题很惊悚,不过还是把你骗进来了,哈哈-各位看官不要着急,耐心往下看 Git是什么 Git是目前世界上最先进的分布式版本控制系统. SVN与Git的最主要的区别 SVN是集中式版本控制 ...

  7. [版本控制之道] Git 常用的命令总结(欢迎收藏备用)

    坚持每天学习,坚持每天复习,技术永远学不完,自己永远要前进 总结日常开发生产中常用的Git版本控制命令 ------------------------------main-------------- ...

  8. 【解决方案】Myeclipse 10 安装 GIT 插件 集成 步骤 图解

    工程开发中,往往要使用到集成GIT ,那么下面说说插件安装步骤 PS:以Myeclipse 10 为例,讲解集成安装步骤. ----------------------main------------ ...

  9. git 命令

    切换仓库地址: git remote set-url origin xxx.git切换分支:git checkout name撤销修改:git checkout -- file删除文件:git rm  ...

  10. git亲测命令

    一.Git新建本地分支与远程分支关联问题 git checkout -b branch_name origin/branch_name 或者 git branch --set-upstream bra ...

随机推荐

  1. VS2010: Microsoft.TeamFoundation.PowerTools.CheckinPolicies.ChangesetComments 未注冊

    VS2010 缺少Team Foundation Server Power Tools 下载地址: http://visualstudiogallery.msdn.microsoft.com/c255 ...

  2. 【JavsScript】当 JavaScript 从入门到提高前需要注意的细节:变量部分

    在javaScript中变量使用var声明的变量是当前作用域的变量,不使用var声明的则肯定是全局变量. http://msdn.microsoft.com/zh-cn/library/dn64545 ...

  3. java Servlet接口及应用

    基本类和接口 一.javax.servlet.Servlet接口 servlet抽象集是javax.servlet.Servlet接口,它规定了必须由Servlet类实现由servlet引擎识别和管理 ...

  4. 关于c中的%x及其它格式化符

    原文:http://blog.csdn.net/lincyang/article/details/6252443 格式化: %x表示按16进制输出:int a = 16;%02x:输出10:%03x: ...

  5. android studio无法更新之解决方案

    当发现android studio有更新时,当然第一时间就想更新,可惜被墙了. 解决方案: 下载wallproxy,百度你懂的 在proxy.ini中最上面,找到ip和port 接着,在android ...

  6. __KERNEL__ macro

    转载:http://blog.csdn.net/kasalyn/article/details/17097639 The __KERNEL__ macro is defined because the ...

  7. 汇编中 .fill 的作用

    .fill     语法:.fill repeat, size, value    含义是反复拷贝 size个字节,重复 repeat 次,        其中 size 和 value 是可选的,默 ...

  8. 关于android在Service中弹出Dialog对话框

    在创建好AlertDialog类型对象后,要 dialog.getWindow().setType(WindowManager.LayoutParams.TYPE_SYSTEM_ALERT); 同时还 ...

  9. MVC框架 - 异常处理

    在ASP.NET中,错误处理是通过使用标准的尝试捕捉方法或使用应用程序事件.ASP.NET MVC附带内置支持,被称为异常过滤器功能异常处理.在这里我们要学习两种方法:一个是定义HandleError ...

  10. 九 AIDL

      多进程 多线程 优点 安全 稳定 扩大内存空间 节约CPU时间 AIDL=Android Interface definition language   使用情况:做一个下载,不想让你的下载拖垮你 ...