Git 总结

今天重新学习了一下廖雪峰老师的git,这套教程写的真是不错,比udacity里面的简洁明了。

下面是我做的一些笔记,供自己参考。

具体请移步:

https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000


1. 创建目录,进入目录并显示当前目录
mkdir xxx
cd xxx
pwd


2. 初始化仓库
git init


3. 提交文件到仓库
git add test1.txt test2.txt
git commit -m "xxx"


4. 查看状态
git status
git diff test.txt 

git log
git log --pretty=oneline

5. 版本回退
git reset --hard HEAD^      //上一个版本
git reset --hard xxxx       //回退到特定的版本号
git reflog //查看命令历史


6. 撤销修改
git reset HEAD test.txt      //丢弃暂存区 unstage (把add的文件取消掉)
git checkout -- test.txt     //丢弃工作区修改


7. 删除文件
git rm test.txt
git checkout --test.txt //还原


8. 创建SSH KEY
ssh-keygen -t rsa -C "youremail@example.com"

默认存放在  /c/Users/admin/.ssh/id_rsa 
和 /c/Users/admin/.ssh/id_rsa.pub 这两个文件中

打开github, 在“Account settings”-"SSH Keys" 中复制id_rsa.pub中内容到Key中,取一个标题保存


9. 添加远程库
/*可以从GitHub上Clone with SSH
*/相对HTTPS(公开)可以避免在push的时候输入口令,速度更快

git remote add origin git@github.com:lancecm/Android.git
git push -u origin master   //第一次推送
git push origin master      //以后的每一次操作


10. 从远程克隆
git clone git@github.com:lancecm/Android.git、


11. 分支管理
git checkout -b dev         //创建并切换分支dev
git branch dev              //创建分支
git checkout dev            //切换分支
git branch                  //查看当前分支
git merge dev               //合并分支到当前分支
git branch -d dev           //删除分支
git log --graph --pretty=oneline --abbrev-commit //分支合并图
git merge --no--ff -m "xxx" dev                  // 禁用Fast forward, 在分支历史上留下合并信息

/* 一共有两种模式: Fast-forward 和Conclict, 后者需要解决冲突再重新合并,前者在分支历史上看不出合并过*/

12. Bug分支
修复bug时,存储现场,新建bug分支修复后删除,然后回到工作现场
git stash                   //储存工作现场
git stash list              //查看工作现场
git stash apply             //恢复工作现场,不删除stash
git stash drop              //删除stash
git stash pop               //恢复并删除
git stash apply xx          //指定恢复


13. Feature分支
每次新建功能最好单独展开分支
git branch -D <name>        //强制删除未合并分支


14. 多人协作
git remote -v //查看远程库信息

origin 代表远端仓库,按照需求把分支推送到远端
git push origin master
git push origin dev

其他人默认只能看到master分支,若要在分支dev上进行开发,需要创建本地dev
git checkout -b dev origin/dev
git branch --set-upstream dev origin/dev  //指定本地dev与远程分支的链接
 
推送前需要抓取最新远程分支:
git pull                    //抓取origin/dev
若提示冲突,则本地解决冲突
git commit -m "xxx" //提交
git push origin dev //重新推送

15.标签管理
git tag v1.0 //给当前分支打上标签
git log --pretty=oneline --abbrev-commit   //查看历史的commit id
git tag v0.9 xxxxxx         //给指定版本打上标签
git tag //查看标签
git show v1.0 //查看标签信息
git tag -a v0.1 -m "version 0.1 released" xxxxxx          //创建带有说明的标签
git tag -s v0.2 -m "signed version 0.2 released" xxxxxx  //用PGP签名标签
git tag -d v0.1 //删除标签
git push origin v1.0 //推送标签
git push origin tags //推送所有标签
//删除远程标签
git tag -d v0.9
git push origin :refs/tags/v0.9


16. 其他
git config --global color.ui true  //Git加上颜色

远程仓库回退方法:
git push -f 强制推送覆盖远程分支

https://www.cnblogs.com/softidea/p/5916885.html

改写最后一次commit信息:
git ammend
进入vim后,按i,编辑信息,输入:w和:q保存和退出返回git bash

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值