git常用命令大全

git是分布式的,不需要联网,每台电脑都是一个中央仓库
origin是远程仓库的名字

开始

git init在当前路径下创建git仓库
git add readme.txt 把文件修改添加到暂存区,使用命令git add <file>,注意,可反复多次使用,添加多个文件;
git commit -m "add project"把暂存区里的所有修改保存到本地仓库
git status查看当前的状态,哪个文件被修改了之类的. 查看的是提交之前,被修改的文件,或者没有add,没有commit的文件,只要commit之后,这里就看不到什么信息了
git diff readme.txt 具体查看这个文件怎么被修改了 diff也就是difference
注:
commit之前要先add.即便是之前已经add过了的也要在add一次.
如果修改了一个文件两次,只有第一次把修改add了,也就是放入暂存区了,那么commit的时候只会commit第一次的修改

关联远程仓库

git remote add origin git@github.com:mengao/learngit.git把本地仓库和远程仓库关联起来,远程仓库名字:origin
修改远程仓库
git remote set-url origin [url]

git remote 显示远程仓库的名字
git push origin master/dev //推送分支

git log //查看当前,和之前的所有版本,也就是提交历史

回退版本

HEAD 表示当前的版本

git reset --hard HEAD^//回退到上一个版本
git reset --hard HEAD~100 // 会退到之前100个版本

回退

git回退到旧版本后,再用git log 就不会显示新版本了.最新的就是当前的版本.如果知道最新的版本号,可以通过
git reset --hard 1093a 来指定回到未来的版本.版本号可以简写前几位,git会自动寻找.

如果找不到未来的版本id
git reflog //记录了所有的每一次的命令.就可以从中寻找到commit id了,查看命令历史.

几个概念:

  • 工作区:项目的目录
  • 版本库:工作区里的一个.git的目录.
  • 暂存区:HEAD和master分支
  • 分支:git会自动为我们创建一个master的分支
    每次add都会把修改放到暂存区.然后commit会把暂存区里的所有修改提交到分支上.

git checkout -- readme.txt//回到最近一次commit或add时候的状态.

git reset HEAD readme.txt//删除暂存区.但是文件里的修改并没有删除,需要再用checkout命令

git rm readme.txt //删除某个文件
等价于:
rm readme.txt.
然后 git add/rd readme.txt

git push -u origin master
由于远程库是空的,我们第一次推送master分支时,加上了-u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令。

可以给一套代码设置两个远程库

git clone git@github.com:mengao/test.git

使用https除了速度慢以外,还有个最大的麻烦是每次推送都必须输入口令

分支

0.查看分支
git log --graph --pretty=oneline --abbrev-commit
git log

git checkout -b dev :首先,创建dev分支,然后切换到dev分支:
等价于以下两条命令:
git branch dev
git checkout dev

git branch 查看当前分支

git merge dev 合并指定分支到当前分支
git branch -d dev删除分支

git log --graph查看分支合并图
但是,并不是一定要把本地分支往远程推送,那么,哪些分支需要推送,哪些不需要呢?

分支介绍:

master分支是主分支,因此要时刻与远程同步;

dev分支是开发分支,团队所有成员都需要在上面工作,所以也需要与远程同步;

bug分支只用于在本地修复bug,就没必要推到远程了,除非老板要看看你每周到底修复了几个bug;
创建新的bug分支进行修复,修复完之后合并,最后删除.

feature分支是否推到远程,取决于你是否和你的小伙伴合作在上面开发。

总之,就是在Git中,分支完全可以在本地自己藏着玩,是否推送,视你的心情而定

如果从remote clone下来的项目,默认只有master分支,需要手动切换到dev分支

如果修改了一个文件,add之后没有commit,那么要切换分支的话是不可能的.就会要你commit或者存到stash里才可以.

冲突处理

1.一个人已经push了,另一个人push时候冲突的处理:
先push
git push origin dev
发生报错说远程仓库已经有人push且发生冲突了
那么pull
git pull
如果pull失败了,原因可能是没有指定本地dev分支与远程dev分支的连接.设置dev和origin/dev的链接
git branch --set-upstream-to=origin/dev dev

处理冲突的代码,然后:
git add ..
git commit ..
最后再次push
git push origin dev

stash

git stash list //查看stash内容
git stash //把当前的操作存储到stash里,后续可以恢复过来
git stash pop //恢复stash内容的同时,删除stash
git stash apply stash@{0} //

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

推荐阅读更多精彩内容

  • git branch 查看本地所有分支 git status 查看当前状态 git commit 提交 git b...
    猿万阅读 5,053评论 1 45
  • 分布式版本管理工具 git属于分布式 svn集中式 git安装 git初始化一个仓库 其实就是创建了一个.git隐...
    SnowDragonYY阅读 1,504评论 0 0
  • 一、 Git 常用命令速查git branch 查看本地所有分支git status 查看当前状态git comm...
    Yaoxue9阅读 624评论 0 3
  • Git是一个很强大的分布式版本控制系统。它不但适用于管理大型开源软件的源代码,管理私人的文档和源代码也有很多优势。...
    小叮当爱学习阅读 519评论 0 4
  • 脑子发热,突然很想写写"歪瓜裂枣"这四个字. 大家有没有这样的记忆:小时候,大人吃桃子总要挑着那有些裂开口子,长得...
    湯小玉阅读 1,433评论 0 1