Git的基本使用

参考资料:
https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000

git-分布式版本控制系统

集中式 vs 分布式:

  • 集中式
    版本库集中存放在中央服务器上;
  • 分布式
    每一个人电脑都是完整的版本库;
    优势:1、不必联网; 2、丰富的分支管理功能
  • tips
    pwd 显示当前所在路径
    ls -ah 显示当前目录下所有文件(包括隐藏文件)
  • utf-8
    windows自带的记事本编辑utf-8时,会自动在头部添加十六进制字符;
    建议用notepad++代替,并选择utf-8 without bom格式;
  • git只能跟踪纯文本文件的改动;
    图片、视频、microsoft的word是二进制文件,只能覆盖修改,不跟踪每次改动情况;

本地使用

  • 安装
    git config --global user.name "Your Name"
    git config --global user.email "email@example.com"

  • 版本库
    working directory
    repository: stage , master(HEAD指针)

文件状态:
untracked 本地新增
Changes not staged for commit 本地修改
staged add之后

  • 日志查看:
    git log 查看历史版本记录
    (git log --pretty=oneline)
    (git log -- src/a.vue)
    git log --graph查看分支合并图 (git graph 最左侧的一列为当前分支)
    git show commit_id -- src/a.vue 查看指定版本及文件的修改
    git reflog 查看未来版本记录
    git reset --hard commit_id git reset -- hard ^HEAD 恢复到指定版本
    git status查看文件状态
    git diff查看修改内容(对比工作区与版本库里的分支)
    q退出查看
  • 新增或恢复文件
    use git add <file>...to include in what will be committed
    use git rm --cached <file>.. to unstage 新增文件后,由暂存区恢复到本地
    use git reset HEAD <file>... to unstage 新增或修改文件后,由暂存区恢复到本地
    use git checkout -- <file>... to discard changes in working directory
    (用版本库替换本地文件,恢复到最近一次add或commit)
  • 删除文件
    rm kkk
    误删:git checkout -- kkk
    删除版本库:git rm kkkgit commit

远程库

  • 关联远程仓库:
    在本地项目根目录下执行
    git remote add origin git@github.com:myfenni/learngit.git
    git remote rm origin
  • 推送master分支内容到远程仓库
    git push -u origin master 第一次
    git push origin master
  • 提交本地test分支作为远程的master分支
    git push origin test:master
  • 提交本地test分支作为远程的test分支
    git push origin test:test
  • 删除远程的分支
    刚提交到远程的test将被删除,但是本地还会保存的
    git push origin :test
  • 克隆
    git clone

分支管理

  • 创建并切换分支
    git checkout -b dev
    等同于
    git branch dev; git checkout dev
  • 查看本地分支
    git branch
  • 查看远程分支
    git remote -v
  • 合并某分支到当前分支
    git merge dev
    use git merge --abort to abort the merge 停止合并
  • 删除分支
    git branch -d dev

分支切换时对本地文件的影响

  • 本地仅有develop分支,且修改了abc文件未提交时,新建本地master分支并切换到master,adb文件仍存在并处于未提交状态
git branch
//develop
git status
//文件a.b,c待add或commit
git checkout -b master
git status
//文件a.b,c待add或commit
git checkout develop
//文件a.b,c待add或commit
git add .
git commit -m 'add'
git status
//devlop分支处于clean状态,已有adc的修改
git checkout master
//master分支处于clean状态,仍无abc的修改

  • 本地位于develop分支,同时有master分支,且修改了abc文件未提交时,切换到master会失败并提示:”先提交本地修改再切换分支“
git branch
//develop(位于),master
git status
//文件adc待add,或commit
git checkout master
//提示,先commit本地修改,才能切换分支
git add .
git commit -m 'add'
git status
//devlop分支处于clean状态,已有adc的修改
git checkout master
git status
//master分支处于clean状态,仍无abc的修改
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,496评论 6 501
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,407评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,632评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,180评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,198评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,165评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,052评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,910评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,324评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,542评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,711评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,424评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,017评论 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,668评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,823评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,722评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,611评论 2 353

推荐阅读更多精彩内容

  • 1.git的安装 1.1 在Windows上安装Git msysgit是Windows版的Git,从https:/...
    落魂灬阅读 12,661评论 4 54
  • 一、前言: 关于git的学习最早是来源于廖雪峰帅哥的官网,通俗易懂,场景众多。不过最近在掘金上看了一个帅哥的文章,...
    前端小学生_f675阅读 271评论 0 0
  • 一. 掌握 - git 概述 1. git 简介? 什么是git? > git是一款开源的分布式版本控制工具 > ...
    Louis_hey阅读 506评论 1 3
  • Git 基础 基本原理 客户端并不是只提取最新版本的文件快照,而是把代码仓库完整的镜像下来。这样一来,任何一处协同...
    __silhouette阅读 15,880评论 5 147
  • Git的使用心得 由于公司对我的代码管理不严谨,所以荒废了好久的Git,一直就没怎么用,后面也多忘光了,所以再次重...
    IUVO阅读 296评论 0 1