一.如何学习git指令

1.查看帮助:git help
2.查看指定命令:git help clone
3.搜索关键字:/chone
4.退出帮助文档:输入Q

二.常见命令

1.初始化git本地仓库:先进入目标文件夹然后输入git init
2.创建文件:touch car.h
3.查看文件状态:git status
查看最新改动:git diff 文件名
4.添加到git暂缓区:git add Car.h
5.添加多个文件到暂缓区:git add .
6.提交代码:gitcommit -m “说明”
7.第一次需要设置账户的用户名和email

  1. git config --global user.name "xxx"
  2. git config --global user.email xxx.me@gmail.com

红色文件:文件没有被纳入到git管理中
绿色文件:文件加入到了‘暂存区’

三.配置账号信息(一般来讲只需配置一次全局的账号即可)

配置局部信息

  1. git config user.name "xxx"
  2. git config user.email xxx.me@gmail.com

配置全局信息
git config --global user.name "xxx"
git config --global user.email xxx.me@gmail.com

1.如果没有配置过账号信息,那么git会有一个默的账号信息
2.如果配置的是全局信息那么
查看账户信息

  1. cat ~/.gitconfig

修改全局信息

  1. gedit ~/.gitconfig

四.查看日志

1.git log
2.一次显示一行

  1. git log --pretty=oneline

五:回退版本

如果文件已经被commit 可以通过git reset来回退版本
1.在Git中,用HEAD表示当前版本,上一个版本就是HEAD^,上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100。
现在,我们要把当前版本回退到上一个版本,就可以使用git reset命令:

  1. $ git reset --hard HEAD^

2.回到某个版本:

  1. $ git reset --hard 3628164

3.检出当前分支的最高版本:

  1. git checkout Car.h

4. 用来记录你的每一次命令,可以在这里看到程序

  1. git reflog

5.删除文件

  1. git rm -Car.h
    git commit -m “说明”

还原

  1. git checkout -- Car.h

六.github

1.注册github账号
2.创建SSH key 在用户主目录下,看看有没有.ssh目录
id_rsa 私钥
id_rsa.pub 公钥
3.登陆github 打开setting,SSH key界面,点Add SSH key,填上任意Title,在Key文本框里粘贴id_rsa.pub

4.添加远程库,登陆github创建一个新的仓库,然后根据github的提示,在本地的仓库下运行命令
把本地仓库上传到github仓库

  1. git remote add origin git@github.com:liushaocong/learngit.git

在本地仓库的内容推送到远程

  1. git push origin master

从远程库克隆

  1. git clone git@github.com:liushaocong/learngit.git

5.创建一个分支

  1. git checkout -b dev

#-b表示创建并切换相当于一下两条命令

创建一个dev分支$git branch dev

切换到dev分支$git checkout dev

列出所有分支 当前分支前面加*

  1. git branch
  2. * dev
  3. master

在dev分支上修改文件

切换到master分支

  1. git checkout master

合并指定分支到当前分支

  1. git merge dev

删除dev分支

  1. git branch -d dev

两个版本文件冲突,首先解决冲突再提交,合并完成

  1. git log --graph --pretty=oneline --abbrev-commit 分支合并图

合并分支时,如果可能,Git会用Fast forward 模式,但这种模式下,删除分支后,会丢掉分支信息。
如果强制禁用Fast forward模式,Git就会在merge时生成一个新的commit,这样,从分支历史上就可以看出分支信息。
首先,仍然创建并切换dev分支:

  1. $ git checkout -b dev
  2. Switched to a new branch 'dev'

修改readme.txt文件,并提交一个新的commit:

  1. $ git add readme.txt
  2. $ git commit -m "add merge"
  3. [dev 6224937] add merge
  4. 1 file changed, 1 insertion(+)

现在,我们切换回master:

  1. $ git checkout master
  2. Switched to branch 'master'

准备合并dev分支,请注意--no-ff参数,表示禁用Fast forward:

  1. $ git merge --no-ff -m "merge with no-ff" dev
  2. Merge made by the 'recursive' strategy.
  3. readme.txt | 1 +
  4. 1 file changed, 1 insertion(+)

因为本次合并要创建一个新的commit,所以加上-m参数,把commit描述写进去。

合并后,我们用git log看看分支历史:

  1. $ git log --graph --pretty=oneline --abbrev-commit
  2. * 7825a50 merge with no-ff
  3. |\
  4. | * 6224937 add merge
  5. |/
  6. * 59bc1cb conflict fixed
  7. ...

可以看到,不使用Fast forward模式,merge后就像这样:

七.创建标签

首先,切换到需要打标签的分支上

然后敲命令git tag <name>就可以打一个新标签:
git tag v0.1

  1. $ git checkout dev
  2. Switched to branch 'dev'
  3. $ git branch
  4. * dev
  5. master
  6. $ git tag v0.1

可以敲命令git tag 查看所有的标签

忘了打标签可以找到历史提交的commit id,然后打上

  1. &git log --pretty=oneline --abbrev-commit
  2. 3d919ae add merge
  3. 902eb16 conflict fixed
  4. d347d7d & simple
  5. c209efc and simple
  6. e0f50b8 branch test
  7. b1f57f6 smile
  1. $ git tag v0.2 c209ef

  

用git show <tagname>查看标签信息

如果标签打错了,也可以删除:

  1. $ git tag -d v0.1
  2. Deleted tag 'v0.1' (was 3d919ae)

创建的标签都只存储到本地,不会自动推送到远程,如果要推送某个标签到远程,使用命令git push origin <tagname>

  1. git push origin v0.1

或者一次性推送全部尚未推送到远程的本地标签

  1. git push origin --tags

如果标签已经推送到远程,要删除远程标签,先从本地删除

  1. git tag -d v0.1

然后,从远程删除。删除命令也是push,但是格式如下:

  1. git push origin :/refs/tags/v0.1

  

Git常用的基本操作的更多相关文章

  1. git常用命令-基本操作

    git常用命令-基本操作 1)      新增文件 新增了Test_1.java git add Test_1.java git commit –m “新增了Test_1.java” git push ...

  2. git常用操作记录

    之前的多人项目大多使用了SVN作为版本控制,自己只会用eclipse连接GitHub的操作.这次项目采用了git作为版本控制系统,所以学会了很多新操作,这里权当记录,以备后用. git的一些基本操作可 ...

  3. Git 常用命令总结,掌握这些,轻松驾驭版本管理

    原创 最近公司的代码管理工具要从SVN转到Git上,因此虽然之前用过Git,但是都是一些简单的推送提交,因此还是有必要进行一些系统的学习,这里做一下笔记,以备后询,且不定期更新. 关于SVN和Git的 ...

  4. Git 常用命令总结,将会持续更新

    平常在windows电脑上使用Git Extensions 工具比较多,大部分的常用指令都可以通过点点点就可以完成.在mac电脑上的话使用sourcetree工具.但有时候也会直接通过git命令,很多 ...

  5. git常用命令(持续更新中)

    git常用命令(持续更新中) 本地仓库操作git int                                 初始化本地仓库git add .                       ...

  6. Git 常用命令

    一.初始環境配置 git config --global user.name "John Doe"git config --global user.email johndoe@ex ...

  7. 记录 git 常用的操作命令总结

    记录 git 常用的操作命令总结 2016-12-15 16:44:04 作为一名开发者,熟悉使用 git 代码管理工具是一项必备的基本技能.git 相较 SVN 而言,其优点不言而喻.git 的功能 ...

  8. Git 常用命令详解

    Git 是一个很强大的分布式版本管理工具,它不但适用于管理大型开源软件的源代码(如:linux kernel),管理私人的文档和源代码也有很多优势(如:wsi-lgame-pro) Git 的更多介绍 ...

  9. git常用的命令集合

    Git 是一个很强大的分布式版本控制系统.它不但适用于管理大型开源软件的源代码,管理私人的文档和源代码也有很多优势. Git常用操作命令: 1) 远程仓库相关命令 检出仓库:$ git clone g ...

随机推荐

  1. mysql 维护添加远程主机访问

    https://www.cnblogs.com/JNUX/p/6936548.html

  2. c51中的bit,SBIT

    在51单片机的0x20~0x2f,是bdata区既可以字节寻址又可以位寻址.用法: 1 先用bdata存储类型关键字 定义变量,注意其值就是地址 .unsigned char bdata MYBITS ...

  3. elasticsearch的模糊查询

    https://blog.csdn.net/a772304419/article/details/78951561

  4. Longest Increasing Subsequence的两种算法

    问题描述:给出一个序列a1,a2,a3,a4,a5,a6,a7-.an,求它的一个子序列(设为s1,s2,-sn),使得这个子序列满足这样的性质,s1<s2<s3<-<sn并且 ...

  5. sql server Cannot resolve the collation conflict between "Chinese_PRC_BIN" and "Chinese_PRC_CI_AS" in the equal to operation

    今天查询二个db,出现这个错误,二种方法,一种是把db里的collation改成一样的:如果不方便可以直接在sql语句后面转一下: select * from table where crm_mscr ...

  6. poj 2411 Mondriaan's Dream (轮廓线DP)

    题意:有一个n*m的棋盘,要求用1*2的骨牌来覆盖满它,有多少种方案?(n<12,m<12) 思路: 由于n和m都比较小,可以用轮廓线,就是维护最后边所需要的几个状态,然后进行DP.这里需 ...

  7. (十二)maven之nexus仓库的基本用法

    nexus仓库的基本用法 ① 启动nexus. 上一章有提到:https://www.cnblogs.com/NYfor2018/p/9079068.html ② 访问http://localhost ...

  8. mohout安装

    安装完成之后的环境变量的配置如下: JAVA_HOME=/usr/local/jdk1.8.0_144JRE_HOME=/usr/java/jdk1.8.0_144/jreCLASSPATH=.:$J ...

  9. Educational Codeforces Round 11 C hard process_补题——作为司老大的脑残粉

    司老大当时教了一种姿势枚举连续K个0,说实话当时比赛写这题完全蒙了 纵然后来知道思路还是写了一段时间 真的是.. 题目大意 n长度的序列,由0 1构成 我们可以改变 k个0为1 求可以得到的最长连续1 ...

  10. Web项目之Django基础

    Django目录: python项目Django(web服务) python项目Django(HTTP协议) python项目Django(Django的安装与使用) python项目Django(U ...