当前位置:   article > 正文

Git常见面试题_git面试题

git面试题

1.git常用命令

1.mkdir  创建文件夹

2.clear  清屏

3. git config --global user.name "Your Name"

   git config --global user.email "email@example.com"

  设置全局的用户名和邮箱

4.git init  把当前的文件夹初始化为本地仓库

5.git add 文件名/.  把文件存到暂存区

6.git commit -m "注释" 把文件存入到本地仓库

7.git diff  查看文件与上一个版本的不同

8.git status 查看当前的版本库的状态

9.git log 查看当前的提交信息

10.git reflog 查看提交命令的日志

11.git reset --hard 版本号  回退版本

12.git clone  远程的地址 把远程仓库克隆到本地并且创建出一个本地仓库

13.git push -u origin master  把本地仓库的内容推送到远程仓库  使用码云

14.git pull  从远程仓库更新内容到本地(它会自动更新内容 自动merge内容)

15.git branch dev  创建分支

16.git checkout dev/git switch 分支名称  切换分支

17.git checkout -b dev /git switch -c 分支名称 切换并创建分支

18.git branch  查看当前的分支

19.git merge 命令用于合并指定分支到当前分支

20.git branch -d  删除分支

21.git remote add origin 远程仓库的地址  把本地仓库和远程仓库连接起来

22.git push -u origin main(github)把本地仓库的内容推送到远程仓库使用github

23.git rm 文件名  删除git仓库中的文件

24.git fetch 从远程仓库更新内容到本地但是不会自动更新需要合并分支到本地(git merge 手动合并)

25.git stash

        保存当前的工作区与暂存区的状态,把当前的修改的保存到git 栈,等以后需要的时候再恢复,git stash 这个命令可以多次使用,每次使用都会新加一个stash@{num},num是编号

26.git stash pop

        默认恢复git栈中最新的一个stash@{num},建议在git栈中只有一条的时候使用,以免混乱

        注:该命令将堆栈中最新保存的内容删除

27.git stash list

        查看当前stash的所有内容

28.git stash apply

        将堆栈中的内容恢复到当前分支下。这个命令不同于 git stash pop。该命令不会将内容从对堆栈中删除,也就是该命令能够将堆栈的内容多次运用到工作目录,适合用与多个分支的场景

        使用方法:git stash apply stash@{$num}

29.git rebase 合并分支保证分支的完美线性

2.Git中git pull和git fetch的区别

git fetch只是将远程仓库的最新的版本下载到本地,但是不会自动merge,相当于工作区中的文件并没有更新

git pull会从远程仓库获取到最新的版本并merge到本地。

git pull origin dev=git fetch origin dev+git merge origin/dev;

git fetch更保险一些,git pull操作更简单

  1. git merge和git rebase的区别

git merge 操作合并分支会让两个分支的共同提交点之后每一次提交都按照提交时间(并不是push时间)排序,并且会将两个分支的最新一次commit点进行合并成一个新的commit,最终的分支树呈现非整条线性直线的形式

git rebase操作实际上是将当前执行rebase分支的所有基于原分支提交点之后的commit打散成一个一个的patch,并重新生成一个新的commit hash值,再次基于原分支目前最新的commit点上进行提交,并不根据两个分支上实际的每次提交的时间点排序,rebase完成后,切到基分支进行合并另一个分支时也不会生成一个新的commit点,可以保持整个分支树的完美线性

  1. GIT提交时发生冲突,如何解决?

为什么会产生冲突?

因为在合并分支的时候,master分支和dev分支恰好有人都修改了同一个文件,GIT不知道应该以哪一个人的文件为准,所以就产生了冲突了。 两个分支相同文件相同位置的的不同操作!

如何解决?

发生冲突,在IDE里面一般都是对比本地文件和远程分支的文件,然后把远程分支上文件的内容手工修改到本地文件,然后再提交冲突的文件使其保证与远程分支的文件一致,这样才会消除冲突,然后再提交自己修改的部分。特别要注意下,修改本地冲突文件使其与远程仓库的文件保持一致后,需要提交后才能消除冲突,否则无法继续提交。必要时可与同事交流,消除冲突。

发生冲突,也可以使用命令。

通过git stash命令,把工作区的修改提交到栈区,目的是保存工作区的修改;

通过git pull命令,拉取远程分支上的代码并合并到本地分支,目的是消除冲突;

通过git stash pop命令,把保存在栈区的修改部分合并到最新的工作空间中;

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/笔触狂放9/article/detail/457289
推荐阅读
相关标签
  

闽ICP备14008679号