git简单使用


git介绍

git是分布式版本控制系统,SVN是集中式版本控制系统;集中式必须在同一网络中才可使用,分布式却不需要联网,且git还具有强大的分支管理。
git中还存在暂存区,所有添加未提交的信息全部保存在暂存区中;当提交后,暂存区就没有内容了。


Linux安装git

  1. 查看是否有安装git输入:git
  2. 未安装git则输入指令:sudo apt-get install git
  3. 如果具有源码安装包依次输入:./configmakesudo make install

指令介绍

初始化仓库:git init
查看状态:git status
添加文件readme.c:git add readme.c
添加所有内容:git add -A
查看修改了什么内容:git diff xxxx.c
提交:git commit -m "xxxxx"//可以写注释信息
查看提交的历史:git log
查看命令历史:git reflog
查看xxx.c文件被修改的地方:git diff xxx.c
撤销未提交的修改readme.c:git checkout -- readme.c
删除文件readme.c:git rm readme.c
配置status别名st:git config --global alias,st status

查看分支:git branch
切换分支到dev:git checkout dev
创建并切换分支到dev:git checkout -b dev
合并分支dev到当前分支:git merge dev
删除分支dev:git branch -d dev
强制删除分支dev:git brach -D dev
重命名本地分支:git branch -m oldName newName

创建标签(类似于版本库的快照 -> 指向某个commit的指针)
创建标签V1.0.0:git tag V1.0.0
创建标签V1.0.0并指定标签信息2020:git tag -a V1.0.0 -m "2020"
删除标签V1.0.0:git tag -d V1.0.0
单个标签V1.0.0推送:git push origin V1.0.0
本地全部标签推送远程:git push origin --tags
删除远程标签V1.0.0:git push origin --delete tag V1.0.0
展示标签V1.0.0的信息:git show V1.0.0

未提交修改藏匿:git stash -> 此时修改信息被隐藏
查看藏匿的工作现场:git stash list
工作现场恢复,但不删除:git stash apply
删除stash内容:git stash drop
恢复现场并删除:git stash pop

远程仓库默认名称为origin
创建远程分支

  1. 先在本地创建分支
    git checkout -b dev
  2. 将本地的分支push到远程
    git push origin dev

远程相关操作:

删除远程分支:git push --delete origin dev
获取远程分支:git pull
设置本地dev分支与远程orgin/dev分支的链接:git branch --set-upstream dev origin/dev

回到上一个版本:git reset --hard HEAD^
回到上上一个版本:git reset --hard HEAD^^
回到100个版本前:git reset --hard HEAD~100
回到指定版本:git reset --hard xxxxxxx//指定版本的commit id(一般取前7位)
查看相应版本commit id:git reflag
commit号由git loggit reflag查看时显示


示例功能

分支管理策略

在合并分支时,git会使用"Fast forward"模式,此模式下,删除分支后,会丢掉分支信息;如果禁用"Fast forward"模式,git就会在merge时生成一个新的commit,这样,从分支历史上就可以看出分支信息。即–no-ff方式。

git checkout -d dev  //创建并切换dev分支
...............  //修改相关内容
git add -A   //添加所有文件
git commit -m "*****"   //提交新的commit
git checkout master  //切换回master

//合并分支dev 且禁用"Fast forward"
//合并后并创建一个新的commit,所以具有-m参数,并把commit描述写进去
git merge --no-ff -m “merge with no-ff” dev  

Bug分支

#存在bug100时,此时分支dev上进行的工作还未提交
git status //查看当前状态
git stash  //保存当前工作区
git checkout master  //切换分支到master
git checkout -b bug_100  //创建并切换到分支bug_100
..........  //修改相关错误
git add xxxx.c //添加修改
git commit -m "*******"  //提交修改
git checkout master  //切换到master分支
git merge --no-ff -m "merged bug 100" bug_100  //合并分支
git branch -d bug_100 //删除分支bug_100

git checkout dev  //切换最开始的工作分支
git status  //查看状态 其工作区无修改
git stash list //查看隐藏工作区
git stash pop  //恢复工作区并删除stash内容
git stash list  //此时无stash内容

多人协作

#远程仓库的默认名称origin
git remote -v  //获取可以抓取和推送的origin的地址 如果无权限则看不到
git push origin master  //推送分支master到远程库


#远程目录克隆
git clone git@github.com:xxx/xxxx.git  //
//创建远程origin的dev分支到本地
git checkout -b dev origin/dev
git commit -m "xxxxx"  //提交
git push origin dev  //将dev分支push到远程
#推送失败 需要把最新的提交抓取下来 然后在本地合并 解决冲突后再推送
git pull //失败则需要设置链接
git branch --set-upstream dev origin/dev  //设置dev和origin/dev的链接
git pull   //再次抓取
..........  //解决冲突
git commit -m "xxxxx"   //提交
git push origin dev   //再push


#如果git pull提示"no tracking information",则说明本地与远程分支的链接关系未创建
git branch --set-uptream branch_name origin/branch_name

配置别名

#git st 等效于 git status
git config --global alias.st status
#同理:
git config --global alias.co checkout
git config --global alias.ci commit
git config --global alias.br branch

git config --global alias.unstage 'reset HEAD'
#即可为:`git unstage test.c` ==> `git reset HEAD test.c`
#同理:
git config --global alias.last 'log -l'

忽略文件

对于不想添加的文件,可以在主文件夹中创建.gitignore文件,不添加某些文件以及文件夹。比如:

#不添加.o、.so、.egg文件以及Preject、build文件夹

*.o
*.so
*.egg
/Preject
/build
!.gitignore # 不忽略

参考资料:Git教程By廖雪峰

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值