Git常用操作

基础命令

git init将该文件初始化为一个git仓库,同时自动创建第一个分支master

git add <filename>将“修改”加到暂存区(Stage),可以添加多个,修改包括“新增、删除、改动”等变化

git commit -m "commit message"一次性将暂存区的所有“修改”提交到当前分支中

git status查看仓库当前状态

git diff查看内容的变化

时光机
回退版本

git log查看由近至远的提交记录,简化版本加上参数--pretty=online

git reset --hard <version>回退到指定版本

方式一:用HEAD表示指向最新版本的指针,HEAD^表示上一个版本,HEAD^^表示上上个版本,HEAD~100表示上100个版本

方式二:可以用commit id来表示版本,只需要写前五六位即可

当找不到被回退的新版本,可以使用git reflog来查找,其记录了每次操作

撤销修改

git checkout --filename此处特指添加了参数--filename

场景一:文件修改后还未add,使用后从工作区删除修改,即git status不会显示有修改

场景二:文件已add,还未commit,需要先使用git reset --hard HEAD <filename>撤销暂存区的修改,回到场景一,再操作

场景三:文件已commit,还未push,直接用git reset --hard <version>回推到上一版本

删除文件

先把工作区的文件自行删除,然后执行git rm filename,再commit

如果是误删,直接使用git checkout --filename,其实checkout表示用版本库中的版本替换工作区的版本,无论是删除还是修改,都可以“一键还原”

远程仓库

git remote add origin git@github.com:Unintented/repo-name.git关联一个远程仓库,默认名称叫做origin,而该远程仓库的默认分支为master

git push -u origin master第一次推送master分支所有内容(其实是--set-upstream的简写版),主要用来将当前本地分支与远程仓库originmaster分支关联,同时push

p.s. 与远程仓库进行关联失败,可以尝试更换ssh公钥

git push origin master后续推送最新修改

git clone git@github.com:Unintented/repo-name.gitssh方式克隆远程仓库,速度快

git remote -v查看已添加的远程仓库

git branch -a查看所有分支,红色表示远程分支

分支管理
创建与合并分支

一开始,master分支是一条线,指向最新的提交,而HEAD指向“当前”分支,可以来回在不同分支之间切换

新创建的分支(一个指针,比如dev)初始指向最新提交,也就是master指向的提交,当把HEAD指向dev时,表示当前分支在dev上。

此后,修改与提交就是针对dev分支进行的了,如新提交一次,dev指针向前移一步,而master指针不变

当在dev上的工作完成后,就可以把dev合并到master上,最简单的情况就是直接将master的指针指向dev

合并后,可以将dev分支删除掉,也就是直接将dev指针删除掉

git switch -c <name>创建+切换分支

git branch <name>创建分支

git switch <name> 切换分支

git branch查看分支

git merge <name>合并分支到当前分支

git branch -d <name>删除分支

其他复杂操作可以直接使用例如git branch --help的方式查看官方解释

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值