一、新手上路

最重要的4招:

1. 初始化本地仓库

git init

或者

git clone 远程仓库地址

2.添加改动文件

git add 改动的文件名或者目录

偷懒的话可以直接

git add .

.表示添加当前目录及子目录下的所有改动文件

3.提交改动

git commit -m "改动原因"

若一次提交所有更改,则使用-a参数可以省略git add命令

git commit -a -m "改动原因"

4.推送到远程仓库

git push

二、常用命令

git status:查看所有未提交的改动

git diff:逐条查看代码具体变动(随时按q键退出)

git log:查看git的提交记录

git reflog:查看所有分支所有操作记录,包括commit和reset操作,以及被删除的commit记录

git reset:回退操作

三、 实用操作

1. 用远程仓库覆盖本地

git fetch -all
git reset -hard origin/master #master可以修改为其他分支
git pull

2.版本回退

已提交且推送的回退:

git reset --hard HEAD^
git push -f

已提交但未推送的回退:

git reset --hard origin/master

未提交的回退:

git reset --hard

hard参数可以换成soft、mixed,意义如下:

--soft:仅仅恢复头指针,已经add的暂存区和工作空间的所有文件都不变

--mixed:恢复头指针,已经add的暂存区也会丢失,但工作空间的代码不变

--hard:恢复头指针,add的暂存区消失,工作空间的代码也恢复到以前状态

HEAD^参数可以换成head、HEAD^^、HEAD~n,或者版本号等,意义如下:

head:回退到当前版本

HEAD^:回退到上一个版本

HEAD^^:回退到上上一个版本

HEAD~3:回退到往上3个版本

HEAD~4:回退到往上4个版本

e1bd3bf:回退到e1bd3bf版本(版本号可通过git reflog命令查看)

......

3.分支合并

合并远程分支dev到本地

git fetch origin dev:dev2  #创建远程分支dev的本地分支dev2
git merge dev2
git branch -d dev2

若改动不多,也可以直接拉取

git pull 远程仓库分支

此时git pull = git fetch +git merge

4.忽略文件

将忽略的文件名后缀或目录写入.gitignore,清空本地缓存

git rm -r --cached .  #最后的点号可以换成目录名或文件后缀名

git入门123的更多相关文章

  1. Git入门图文教程(1.5W字40图)🔥🔥--深入浅出、图文并茂

    01.认识一下Git!-简介 Git是当前最先进.最主流的分布式版本控制系统,免费.开源!核心能力就是版本控制.再具体一点,就是面向代码文件的版本控制,代码的任何修改历史都会被记录管理起来,意味着可以 ...

  2. git入门网站

    http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000 git入门教程:对商业的.开源的. ...

  3. git入门及上传项目到github

    Git入门:       如果你完全没有接触过Git,你现在只需要理解通过Git的语法(敲入一些命令)就可以将代码上传到远程的仓库或者下载到本地的仓库(服务器),我们此时应该有两个仓库,就是两个放代码 ...

  4. Git入门仅这篇就够了

    版权声明:本文为博主原创文章,未经博主允许不得转载. 转载请表明出处:http://www.cnblogs.com/cavalier-/p/5978937.html 前言 大家好,我是Cavalier ...

  5. git入门学习(二):新建分支/上传代码/删除分支

    一.git新建分支,上传代码到新的不同分支  我要实现的效果,即是多个内容的平行分支:这样做的主要目的是方便统一管理属于同一个内容的不同的项目,互不干扰.如图所示: 前提是我的github上已经有we ...

  6. git入门学习(一):github for windows上传本地项目到github

    Git是目前最先进的分布式版本控制系统,作为一个程序员,我们需要掌握其用法.Github发布了Github for Windows 则大大降低了学习成本和使用难度,他甚至比SVN都简单. 一.首先在g ...

  7. Git入门简介

    ​1. Git 背景 Git 最初由Linus Torvalds编写,用于 Linux 内核开发的版本控制工具. Git 与常用的版本控制工具 CVS.Subversion 等不同,它采用了分布式版本 ...

  8. [置顶] 【Git入门之十五】Github操作指南

    原创作品,转载请标明:http://blog.csdn.net/jackystudio/article/details/12374633 最终篇,介绍一下Github网站的使用,主要是翻译为主,简化了 ...

  9. Git入门—创建项目

    Git入门—创建项目 注:win10系统下 打开Git Bash,进入存放仓库的目录 创建 初始化git init,该命令执行完后会在当前目录生成一个 .git 目录. 所有 Git 需要的数据和资源 ...

  10. git 入门教程

    git 入门教程之协同开发 前面我们已经介绍过远程仓库的相关概念,不过那时并没有深入探讨,只是讲解了如何创建远程仓库以及推送最新工作成果到远程仓库,实际上远程仓库对于团队协同开发很重要,不仅仅是团队协 ...

随机推荐

  1. go 程序设计语言 命令行参数

    最近打算读一读 go程序设计语言这本书, 读语言类的书是一件十分头疼的事情, 因为读一本书就意味着,看着一堆钳子 锥子工具的图片, 概念背了一大堆,仍然不知道怎么用,还是要通过实践. 还是习惯任务驱动 ...

  2. Django中遇到的问题

    1.如右上角无Dj的 Django标识 解决方法1: 关闭Pycharm 重启创建项目,进入到Django的所在目录下 解决方法2: 方法3: 第一步: 第二步: 第三步: 第四步: 2.如下图:显示 ...

  3. SSM项目集成Redis

    1. 加入依赖 <!--redis--> <dependency> <groupId>redis.clients</groupId> <artif ...

  4. vue页面添加锚点后 点击不改变URL

    html: <a @click="changeHash('#row')"> {{ $t("msg.desc1") }} </a>   j ...

  5. P2016题解

    P2016题解 题目描述 Bob要建立一个古城堡,城堡中的路形成一棵无根树.他要在这棵树的结点上放置最少数目的士兵,使得这些士兵能瞭望到所有的路. 注意,某个士兵在一个结点上时,与该结点相连的所有边将 ...

  6. BS4&xpath的使用

    0|1一 简介 简单来说,Beautiful Soup是python的一个库,最主要的功能是从网页抓取数据.官方解释如下: ''' Beautiful Soup提供一些简单的.python式的函数用来 ...

  7. 《CSOL大灾变》Mobile开发进度记录——扔掉与拾取武器的逻辑

    在武器系统的开发过程中,涉及到武器的丢弃逻辑.由于场景是复制场景,而自己写碰撞测试和抛物线以及重力下落来模拟扔掉一把武器,并且要防止武器扔到墙里.如果自己实现这些逻辑,那么会占用渲染线程的时间开销,即 ...

  8. java读取apk、ipa包名、版本名、版本号等信息

    package com.gymexpress.exerciseservice.controller;import com.gymexpress.commonmodel.controller.BaseC ...

  9. 关于sqlsugar二级缓存

    二级缓存 1.优点 (1).维护方便:SqlSugar的 二级缓存 支持单表和多表的 CRUD 自动缓存更新 ,减少了复杂的缓存KEY维护操作 (2).使用方便:可以直接在Queryable.With ...

  10. 记录一次阿里云ECS搭建代理服务器的过程

    [参考资料](Tinyproxy安装与配置(ip代理) - 林先生 (downdawn.com)) 1.一键安装脚本 vim proxy.sh #! /bin/bash # 配置文件 CONFIG_F ...