Git - 相关操作

想从添加秘钥看起请点击:在macOS 上首次使用 Git 的基础教程

查看本地Git配置信息

git config --local --list   查询当前Git配置

git config user.name

git config user.email 查询当前的 用户名 /邮箱


查看项目的所有分支情况

git branch -a 查看本地+远程的所有分支

与分支相关的操作

git branch  //查看当前所有的分支(当前所在的分支会   标绿加* )

git branch newBranch-001  //新建一个名叫《newBranch-001》的分支

git checkout  newBranch-001  //当前分支切换至《newBranch-001》分支
//上面两句可以合并,灵活使用
git checkout -b  newBranch-001 //先new再切换到此新分支上

git branch -d Issue-001 //删除《Issue-001》分支

git branch -r -d Issue-001 //删除《origin/Issue-001》的远程分支

以远端仓库为准,拉取远端内容

git pull --rebase origin master  在远端的基础上拉取最新内容,用于首次 push 不成功的情况

最常用操作

git status  最常用的,查看当前工作区|缓存区

git diff  balabala.text 查看《balabala.text》文件工作区与缓存区的不同地方

git add  balabala.text  把当前工作区的《balabala.text》文件添加到缓存区

git commit -m "老板是煞笔"  把当前缓存区的全部内容提交为一个版本

//以上两步(git add\ git commit)可以合并为(git commit -m -a "描述"),但强烈不推荐!!!
//(因为它只会把默认更新提交,“新增默认不存入缓存区” 不会被提交!!!)
//(简单理解就是一部分文件[往往最重要!]不会被提交,具体百度或者自己尝试一次就懂了)
//git commit -m "描述" -a   //把当前“变更” [但不包含增加]添加到缓存区并进行提交

//如果在 push之前发现 commit 描述文字错误,或单纯修改上次提交的文字描述
git commit --amend  查看并修改最近一次的提交内容
//这里可以使用vi修改 (把"老板是煞笔" 修改为 "老板加鸡腿")

---
---
//确认本地需要提交的信息无误后
git push  把本地仓库推送到远程仓库

查看历史操作

git log --pretty=oneline  //打印所有历史操作,可以快捷查看每个操作的缩略码

git reflog 打印所有的命令记录(主要是从未来回到过去后,用log无法找到未来的id)

git log --graph --pretty=oneline --abbrev-commit //以缩略图形式,展示分支合并信息

后悔药,reset-- hard 操作,慎用!

git reset --hard  (6位id值)  回退到某一ID对应的版本(既可以是过去,也可以是未来)

对缓存区的操作

git rm bala.text  //删除缓存区内的《 bala.text》文件

git checkout -- bala.text  
//用缓存区的《bala.text 》文件替换工作区对应《bala.text 》文件的内容。
//就这一点来看,可以有“删除当前内容”和“回退之前内容”两层含义。
//未add时,删除当前工作区的内容很容易理解;
//回退 的话要与  git reset --hard  (过去正确的版本id) 联合使用,
//先回退版本,再checkout该文件,就回退到了该文件还存在的时刻。

  • 合并分支 (不要让新手合并代码!!!)

就像不要让新手去写css

需要先搞清楚一个基本道理:

假设:

主分支用[master]表示; 次要分支用[issue]表示

则:

要把 issue 合并到 master 之上,就首先把当前分支切换至目标分支——master上,再在master上merge issue。


很自然,也很基本。但我们平时开发总是在issue上的开发,检查好要往主分支合并时,新手很容易合并反,直接在issue 上merge other了,搞得乱七八糟的。

merge合并语句

git merge Issue-001  把《Issue-001》分支内容合并到当前分支之中

//merge 后一般就删除分支了
git branch -d Issue-001 删除《Issue-001》分支

git branch -r -d Issue-001 删除《origin/Issue-001》远程分支

合并时解决冲突

可以使用vim 直接操作,建议使用。Vim 语法传送门
也可以进入工程文件手动更改。

vi a.rtf 

在需要的地方 dd (删除)

最后  :wq (保存并退出)

解决完冲突就可以继续提交代码了

//注意喽,这里可都是在develop分支上的操作
git status

git add  aaa.text  //之前冲突的文件

git commit -m "解决1.03版本冲突"  

git push

以缩略图形式,展示分支合并信息

git log --graph --pretty=oneline --abbrev-commit //以缩略图形式,展示分支合并信息

高阶玩法 (有风险,慎用!!!)

把本地分支嫁接到某一远端分支节点

git fetch

git reset --hard origin/isuue-100 

最后记录一下版本合并的原则。

Origin 远端仓库,不解释

Master 权高位重,可以认为是“成熟版本”的记录者,它的每一次节点的更替,都意味着一个“经得起线上检验的”版本。面向版本,而不是面向功能。

Develop 战线最长,面向功能。可以认为是“完整新功能”的记录者,它的每一次节点更替,意味着一个“完整的功能”。一个版本可以有若干新旧功能。

Future 一般用于打某几个功能的较完整的测试包。比如开发周期为两周,第一周只完成ABC三个功能,D功能完成一半,就先把ABC merge 到Future中,查看整体效果,或用于展示。最终Future将在功能测试后销毁,不建议合并至Develop中!

Issue 分支,面向功能模块,(或者说面向文件,尽可能只修改某一功能所涉及的某几个文件,尽量避免因不同的Issue修改同一文件而造成的合并冲突)可能包含一个或多个近似功能实现。需要就开辟,弃用即销毁,完成就rebase merge 到Develop中,实现 “某一功能开发完成”,或“针对性修改某一单一功能”的目的。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,185评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,445评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,684评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,564评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,681评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,874评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,025评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,761评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,217评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,545评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,694评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,351评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,988评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,778评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,007评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,427评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,580评论 2 349

推荐阅读更多精彩内容