第五讲 git

学习网站:https://learngitbranching.js.org/?locale=zh_CN

git就是像一棵树一样,把所有历史记录存储下来,并且支持多分支

git基本概念 

  • 工作区:仓库的目录。工作区是独立于各个分支的(即不管在哪个分支,工作区都是同一个)。
  • 暂存区:数据暂时存放的区域,类似于工作区写入版本库前的缓存区。暂存区是独立于各个分支的。
  • 版本库:存放所有已经提交到本地仓库的代码版本
  • 版本结构:树结构,树中每个节点代表一个代码版本。

git常用命令

全局设置

1,git config --global user.name xxx:设置全局用户名,信息记录在~/.gitconfig文件中

2,git config --global user.email xxx@xxx.com:设置全局邮箱地址,信息记录在~/.gitconfig文件中

3,git init:将当前目录配置成git仓库,信息记录在隐藏的.git文件夹中

就是选中或者创建一个专门的文件夹,将该文件夹设置成git仓库

常用命令

1,git status:查看仓库状态

(1)

 表示有文件还没有被加入暂存区,可以用"git add <file>"加入

(2) 

表示文件已经被加入暂存区

(3)如果修改文件,因版本已经变化,需要重新放入暂存区和版本区

2,git add XX:将XX文件添加到暂存区

  • git add .:将所有待加入暂存区的文件加入暂存区 

不仅可以add增加和修改,也可以add删除 

3,git commit -m "给自己看的备注信息":将暂存区的内容提交到当前分支

每次commit完暂存区会清空

 4,git log:查看当前分支的所有版本(从当前到empty(根))

即沿着当前路径

(1)美观操作

输入命令:git log --pretty=oneline

5,git push -u (第一次需要-u以后不需要):将当前分支推送到远程仓库(即将本地同步到云端)
git push origin branch_name:将本地的某个分支推送到远程仓库

6,git clone git@git.acwing.com:xxx/XXX.git:将远程仓库XXX下载到当前目录下

7,git branch:查看所有分支和当前所处分支

查看命令

1,git diff XX:查看XX文件(尚未缓存)相对于暂存区修改了哪些内容,如果暂存区没有存内容,就表示头结点指向的版本(即当工作区有改动,临时区为空,diff的对比是“工作区与最后一次commit提交的仓库的共同文件”;当工作区有改动,临时区不为空,diff对比的是“工作区与暂存区的共同文件”。)

2,git status:查看仓库状态

(1)

 表示有文件还没有被加入暂存区,可以用"git add <file>"加入

(2) 

表示文件已经被加入暂存区

(3)如果修改文件,因版本已经变化,需要重新放入暂存区和版本区

 3,git log:查看当前分支的所有版本(从当前到empty(根))

即沿着当前路径

(1)美观操作

输入命令:git log --pretty=oneline

4,git reflog:查看HEAD指针的移动历史(包括被回滚的版本) 

5,git branch:查看所有分支和当前所处分支

6,git pull:将远程仓库的当前分支与本地仓库的当前分支合并(即将云端同步到本地)
git pull origin branch_name:将远程仓库的branch_name分支与本地仓库的当前分支合并

删除命令

1,git rm --cached XX:将文件从仓库索引目录中删掉

2,git restore --staged  XX:将暂存区的XXX清空 工作区不变

(即是把 git add filename 放在暂存区的 filename 文件删除到工作区  ( staged 就是暂存区的意思))

3,git checkout — XXgit restore XX:将XX文件尚未加入暂存区的修改全部撤销

(即将修改的 filename 文件回滚到暂存区 (filename 还没有放到暂存区)如果暂存区没有东西,是空的话就回滚到 HEAD 指向的文件)

代码回滚

 1,git reset --hard HEAD^git reset --hard HEAD~:将代码库回滚到上一个版本

  • git reset --hard HEAD^^:往上回滚两次,以此类推
  • git reset --hard HEAD~100:往上回滚100个版本
  • git reset --hard 版本号:回滚到某一特定版本
  • git reset .:清空暂存区的文件

远程仓库

1,git remote add origin git@git.acwing.com:xxx/XXX.git:将本地仓库关联到远程仓库

2,git push -u (第一次需要-u以后不需要):将当前分支推送到远程仓库(即将本地同步到云端)
git push origin branch_name:将本地的某个分支推送到远程仓库

3,git clone git@git.acwing.com:xxx/XXX.git:将远程仓库XXX下载到当前目录下

4,git push --set-upstream origin branch_name:设置本地的branch_name分支对应远程仓库的branch_name分支

5,git push -d origin branch_name:删除远程仓库的branch_name分支

6,git checkout -t origin/branch_name 将远程的branch_name分支拉取到本地

7,git pull:将远程仓库的当前分支与本地仓库的当前分支合并(即将云端同步到本地)
git pull origin branch_name:将远程仓库的branch_name分支与本地仓库的当前分支合并

8,git branch --set-upstream-to=origin/branch_name1 branch_name2:将远程的branch_name1分支与本地的branch_name2分支对应

分支命令

1,git branch branch_name:创建新分支

2,git branch:查看所有分支和当前所处分支

3,git checkout -b branch_name:创建并切换到branch_name这个分支

4,git checkout branch_name:切换到branch_name这个分支

5,git merge branch_name:将分支branch_name合并到当前分支上

6,git branch -d branch_name:删除本地仓库的branch_name分支

7,git push --set-upstream origin branch_name:设置本地的branch_name分支对应远程仓库的branch_name分支

8,git push -u (第一次需要-u以后不需要):将当前分支推送到远程仓库(即将本地同步到云端)
git push origin branch_name:将本地的某个分支推送到远程仓库

9,git checkout -t origin/branch_name 将远程的branch_name分支拉取到本地

10,git pull:将远程仓库的当前分支与本地仓库的当前分支合并(即将云端同步到本地)
git pull origin branch_name:将远程仓库的branch_name分支与本地仓库的当前分支合并

11,git branch --set-upstream-to=origin/branch_name1 branch_name2:将远程的branch_name1分支与本地的branch_name2分支对应

stash暂存

1,git stash:将工作区和暂存区中尚未提交的修改存入栈中

2,git stash apply:将栈顶存储的修改恢复到当前分支,但不删除栈顶元素

3,git stash drop:删除栈顶存储的修改

4,git stash pop:将栈顶存储的修改恢复到当前分支,同时删除栈顶元素

5,git stash list:查看栈中所有元素

tips:

如何删除本地项目:rm 项目 -rf

如何删除云端项目:在github设置中删除

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值