Git仓库
1.创建git仓库
(1)git init:在现有目录下初始化仓库,再通过git add实现对指定文件对追踪;
(2)git clone url:克隆现有的仓库—自动在当前目录下创建目录且初始化一个.git文件夹,然后将从远程仓库拉取下的数据放进.git文件夹,然后将最新版本的文件拷贝进工作目录;
-
git仓库的工作区
(1)工作目录
- 已跟踪文件:从Git仓库提取出文件,以供修改或使用;可通过git rm --cached xx不再跟踪xx文件,但xx文件仍存在在本地目录中,只是不纳入版本控制;
- 未跟踪文件:可通过git add将其变为已跟踪文件;
(2)暂存区:通过git add将已修改/未跟踪的文件从工作目录放入暂存区;
(3)Git仓库:对暂存区的文件使用git commit,提交修改,保存最新版本的文件快照;
Git常见命令
1.git status [-s]
- git add xx
- 开始跟踪新文件xx;
- 将已跟踪的修改过的文件xx放入暂存区;
- 将合并时发送冲突的文件标记为已解决状态;
3.git commit
(1)git commit -m ‘xx’
(1)git commit -a -m 'xx':相当于git add .+ git commit
撤销&回滚
1.撤销文件的修改
(1)git checkout -- <file> :撤销对文件的修改— 将修改前的file文件覆盖了该file,此file的任何修改将会消失;
(2)git reset HEAD <file>:撤销暂存区的文件,取消该文件的git add操作;
2.已commit但未push到远端
(1)git commit --amend [-m 'xxx']:将这次commit与上一次commit合为一个新的commit,即commit版本号会改变,但commit次数不变;
- 提交新的修改但不增加一条新的commit记录;
- 只单纯更改commit的提交信息,若不写则默认使用上次的提交信息;
(2)git reset --xx <commit-id / HEAD~n>:回退到commit-id版本/回退n个版本
-
git reset --soft <commit-id / HEAD~n>:回退到指定版本的commit状态,但保留了所有阶段的git add操作;
- git reset --mixed <commit-id / HEAD~n>: 回退到指定版本的commit状态,但工作目录保留了修改,将目录中所有的修改通过git add即与--soft的指令结果一样
- git reset --hard <commit-id / HEAD~n>:回退到指定版本的commit状态,不保留修改,可通过git reflog找到丢失的commit找回丢失的数据
3.commit之后已push到了远端:git revert
远程仓库&分支
1.git remote:查看远程仓库—列出每一个远程仓库的简写;
(1)git remote -v:显示简写+对应的url;
(2)git remote add <shortname> <url>:添加一个远程仓库,并为其指定一个简写;
(3)git remote show <shortname>:查看该shortname对应的远程仓库的相关信息;
(4)git remote rename x1 x2:将简写名x1改为x2;
(5)git remote rm xx:移除简写名xx对应的远程仓库;
2.远程分支:(remote)/(branch) — 只要不与远程仓库的服务器连接,本地的远程分支指针就不会移动;
3.拉取:本地仓库会自动跟踪对应的远程分支
(1)git fetch 远程仓库:从指定远程仓库中拉取本地没有的数据,但不会合并到本地分支上;
(2)git pull [远程仓库 远程分支]:git fetch+git merge — 查找当前分支所跟踪的服务器分支,从服务器抓取数据然后合并到本地分支;
(3)git pull --rebase [远程仓库 远程分支]:git fetch+git rebase;
[git pull & git pull --rebase]https://www.cnblogs.com/kevingrace/p/5896706.html
4.推送:git push 远程仓库 本地分支:远程分支
5.跟踪远程分支:git checkout -b 分支名 [remote/branch]:将远程仓库的分支拉取到本地分支,并建立跟踪连接—即在该跟踪分支上输入git pull,git能自动识别去哪个服务器上抓取,合并到哪个分支;
6.删除远程分支:git push 远程仓库 --delete 分支名 — 删除远程仓库指定的远程分支;
git分支
1.创建分支
(1)git branch <分支名>:只是新建分支,但不切换分支;
(2)git checkout -b <分支名>:新建并切换到该分支上;
2.分支切换:git checkout <分支名>—HEAD指针指向当前所在分支,其随着commit操作自动向前移动,切换分支即切换工作目录;
3.分支的合并
(1)git merge <分支名>:将指定的分支合并到所在分支上;
-
合并冲突:两个分支对同一文件的同一部分进行了不同的修改则会产生冲突;
- 需要手动去解决冲突,选择要保留的最终内容;
- git add将其标记为冲突已解决;
-
git commit完成合并提交;
(2)git rebase
-
合并冲突
- 手动解决冲突+git add <冲突文件>+git rebase --continue:先处理冲突再继续合并;
- 跳过:git rebase --skip
-
取消合并:git rebase --abort
(3)git cherry-pick <commit-id>:选择某个分支的一个或几个commit进行操作;
- 应用场合
- 把弄错分支的提交移动到正确的地方;
- 把其他分支的提交添加到现在的分支;
- git cherry-pick <start-commit-id>...<end-commit-id>:一次性将一个连续的时间序列内的commit进行cherry-pick操作—不包含start-commit-id的commit;
- git cherry-pick <start-commit-id>^...<end-commit-id>:[左闭,右闭]的区间,即包含了start-commit和end-commit;
- 合并冲突:手动修改冲突 + git add .+git cherry-pick --continue;
(4)区别:比如两个抽屉A与B都装满了衣服,现在想把B中的衣服装入A中,则git merge是强制性的,拿起B就倒入A里,如满了(冲突)再一并整理;而git rebase是一件一件根据一开始放入的顺序从B往A中加,如满了(冲突)你可以选择处理这一件再继续加,或跳过这一件,或不再加了把A还原;
3.分支操作
(1)git branch:查看本地git仓库已有的分支名+所在分支;
(2)git branch -d 分支名:删除本地分支
(3)git branch -vv:查看所有本地分支&本地分支与远程分支的关系