git最新面试题
Git中的分支策略有哪些,它们分别适用于什么场景?
Git的常见分支策略包括:
1、Feature Branch Workflow: 每个功能开发在独立的分支上进行。适用于团队成员需要在不同功能上并行工作的场景。
2、Gitflow Workflow: 包含开发、特性、发布、主分支和维护分支。适用于需要维护多个版本的复杂项目。
3、Forking Workflow: 每个开发者在自己的仓库中工作,适用于开源项目或需要严格代码审查的环境。
4、Trunk Based Development: 所有开发者都在主分支上工作,适用于持续集成和快速迭代的项目。
每种策略根据项目规模、团队结构和发布流程的不同有其适用场景。
Git中的rebase和merge有什么区别?它们各自的优缺点是什么?
Rebase和Merge 是Git中用于合并分支的两种不同方法。它们的主要区别和各自优缺点如下:
1、Rebase: 将一个分支上的修改重新应用到另一个分支上。优点是可以创建更清晰的项目历史;缺点是可能改变历史记录,不适合已经推送到公共仓库的分支。
2、Merge: 将两个分支的历史合并成一个新的提交。优点是保留了完整的历史记录和原有分支的上下文;缺点是可能会产生复杂的分支树。
选择哪种方法取决于项目团队的协作方式和对历史的维护要求。
Git中如何解决冲突?
在Git中解决冲突通常包括以下步骤:
1、识别冲突: 通过Git命令识别出发生冲突的文件。
2、手动编辑: 打开冲突文件,查找标记的冲突区域,并手动解决这些差异。
3、标记为已解决: 在解决了所有冲突后,使用git add
命令将文件标记为冲突已解决。
4、完成合并: 执行git commit
完成合并操作。
在解决冲突的过程中,重要的是要理解不同分支上的变更,确保合并后的文件符合预期。
Git的Cherry-pick命令是什么?它的适用场景是什么?
Git的Cherry-pick命令用于将选定的提交(commit)应用到其他分支。适用场景包括:
1、特定更改的移植: 当需要将一个分支上的特定提交应用到当前分支时。
2、代码回退: 快速撤销已合并到主分支的更改。
3、修复分支: 在开发分支中修复错误后,将修复应用到其他分支。
Cherry-pick是一种灵活的工具,可以在不同分支间迅速移动更改,但需要谨慎使用,以避免潜在的合并冲突。
Git Stash是什么?它的使用场景有哪些?
Git Stash是一个用于临时存储改动的功能,使你可以清理工作目录并切换到其他分支。使用场景包括:
1、中断工作: 当需要处理更高优先级的任务时,可以暂存当前改动。
2、切换分支: 在切换分支前暂存当前分支的未提交改动。
3、合并前准备: 在合并前清理工作目录。
Stash是一个有用的工具,用于管理工作目录和索引的临时改动。
Git的Tag是什么?它通常用于哪些场景?
Git的Tag是指向特定提交的引用,用于标记特定的点,如版本发布。常用场景包括:
1、版本发布: 标记产品的重要版本,如v1.0、v1.1等。
2、里程碑: 标记项目的重要阶段或里程碑。
3、固定点参考: 提供一个固定的参考点,用于代码审查或回退。
Tag为项目的历史提供了清晰的参考点,便于跟踪和维护。
Git中的Submodule是什么?它如何使用?
Git的Submodule允许将一个Git仓库作为另一个Git仓库的子目录。使用方法包括:
1、添加Submodule: 使用git submodule add <repository> <path>
将子仓库添加到父仓库。
2、初始化Submodule: 克隆包含Submodule的仓库后,使用git submodule init
初始化。
3、更新Submodule: 使用git submodule update
拉取子模块的最新更改。
4、管理更改: 在Submodule中的更改需要在子仓库和父仓库中分别提交。
Submodule适用于管理依赖库或独立开发的模块,但需要额外的步骤来管理和更新。
Git中的HEAD、index和工作目录之间有什么区别?
Git中的HEAD、index(暂存区)和工作目录是版本控制的核心组件,它们之间的区别如下:
1、HEAD: HEAD是指向当前分支上最新提交的指针。它是一个引用,指向当前分支的最后一次提交,代表最近的工作状态。
2、index(暂存区): 暂存区是一个临时存储区域,用于记录即将提交到仓库的文件变更。当你执行git add
命令时,变更就会被添加到暂存区。
3、工作目录: 工作目录包含项目的文件和目录,是用户进行编辑和修改的地方。工作目录的改动尚未被提交到Git仓库。
Git中解决合并冲突?
解决Git合并冲突的步骤通常如下:
1、识别冲突: 首先,使用git status
命令来识别所有有冲突的文件。
2、编辑文件: 打开有冲突的文件,查找标记冲突的区域(通常被<<<<<<<
、=======
、>>>>>>>
包围),手动解决这些冲突。
3、暂存更改: 解决完冲突后,使用git add
命令将更改加入暂存区。
4、完成合并: 通过git commit
命令完成合并操作。这将创建一个新的提交,表示冲突已解决。
Git rebase和merge的区别是什么?
Git的rebase和merge都用于整合来自不同分支的更改,但它们的方式和结果有所不同:
1、merge: 合并会创建一个新的“合并提交”,它将两个分支的历史整合在一起。这保留了完整的历史记录,但可能会导致复杂的提交图。
2、rebase: rebase会重新排列提交,它将一个分支的提交应用到另一个分支的顶部。这会产生一个更线性的提交历史,但会改变现有分支的提交历史。
Git中撤销最后一次提交?
在Git中撤销最后一次提交可以通过以下命令实现:
1、git reset --soft HEAD~1
: 这个命令将HEAD指针移回到前一个提交,撤销提交但保留更改内容在暂存区。
2、git reset --hard HEAD~1
: 如果想完全撤销最后一次提交(包括更改),可以使用这个命令。但要注意,这将丢失最后一次提交的所有更改。
Git中的stash是什么,如何使用?
Git中的stash功能用于临时保存未提交的更改,以便在未来某个时间点重新应用。使用方法如下:
1、创建stash: 使用git stash
或git stash save
命令可以将当前的工作进度暂存起来。
2、查看stash列表: git stash list
命令显示所有的stash条目。
3、应用stash: git stash apply
命令应用最近的stash。如果想应用特定的stash,可以使用git stash apply stash@{<number>}
。
4、删除stash: 一旦完成stash的应用,可以使用git stash drop
命令来删除特定的stash条目。
Git中分支策略的最佳实践是什么?
Git中的分支策略最佳实践包括:
1、主分支保持干净: 主分支(通常是master或main)应该始终保持干净且可部署的状态。
2、功能分支用于开发: 对于新功能或修复,应在单独的功能分支上进行开发。
3、定期合并主分支: 定期将主分支的更改合并到功能分支上,以避免分支偏离过多。
4、代码审查: 在合并到主分支之前,应进行代码审查。
Git中创建和使用标签?
在Git中创建和使用标签的步骤如下:
1、创建标签: 使用git tag <tagname>
命令创建一个轻量标签,或者使用git tag -a <tagname> -m "message"
创建一个含注释的标签。
2、查看标签: 使用git tag
命令可以查看所有标签。
3、切换到标签: 使用git checkout <tagname>
可以切换到特定标签。
4、推送标签: 使用git push origin <tagname>
可以推送单个标签到远程仓库,或者使用git push origin --tags
推送所有标签。
Git中的快进合并与非快进合并有什么区别?
快进合并与非快进合并的区别主要在于:
1、快进合并(Fast-forward merge): 如果被合并的分支是合并分支的直接前继,则Git会进行快进合并,即直接将合并分支的指针移动到被合并分支的最新提交。
2、非快进合并(No-fast-forward merge): 如果合并不能进行快进操作,Git会创建一个新的提交来表示合并,这样可以保留原始分支的历史。
16Git中如何查看文件的变更历史?
在Git中查看文件的变更历史可以通过以下命令实现:
1、git log <file>
: 显示特定文件的提交历史。
2、git blame <file>
: 显示文件每一行的最后修改者和修改时间。
3、git diff <file>
: 比较工作目录中的文件和暂存区或最后一次提交的差异。
Git中的cherry-pick命令是什么,如何使用?
Git中的cherry-pick命令用于将某个分支的单个提交应用到当前分支。使用方法如下:
1、找到想要cherry-pick的提交的SHA-1哈希值。
2、在当前分支上执行git cherry-pick <commit-hash>
,将该提交应用到当前分支上。
Git中的reset和revert命令有何区别?
reset和revert在Git中用于撤销更改,但它们的方式不同:
1、reset: reset命令用于将HEAD指针移动到指定的提交,可以选择性地更改索引(暂存区)或工作目录。
2、revert: revert命令创建一个新的提交,这个提交是对指定提交的更改的逆操作,不会改变现有的项目历史。
Git中如何处理大文件或大仓库的性能问题?
处理Git中大文件或大仓库的性能问题的方法包括:
1、使用Git Large File Storage(LFS): Git LFS允许存储大文件而不是在仓库中直接跟踪它们。
2、定期进行垃圾回收: 使用git gc
命令定期清理不必要的文件和优化本地仓库。
3、浅克隆: 对于大仓库,可以使用git clone --depth 1
来进行浅克隆,仅克隆最近的提交以减少下载量。
Git中的三种合并策略是什么?
Git提供了三种主要的合并策略:
1、默认合并(Merge): 这是Git的标准合并策略,当你运行git merge
时,默认使用。它会创建一个新的合并提交来组合两个分支的更改。
2、变基(Rebase): git rebase
命令会将一个分支的所有更改应用到另一个分支的顶部。这可以创建一个更清晰的项目历史,但可能会改变现有的提交历史。
3、压缩合并(Squash): 在合并时使用git merge --squash
可以将所有更改压缩成一个提交。这使得历史更整洁,但可能会丢失一些合并分支的历史细节。
Git中恢复已删除的分支?
恢复已删除的Git分支可以通过以下步骤实现:
1、找到最后一次提交: 使用git reflog
查找最后一次提交到删除的分支的记录。
2、创建新分支: 使用找到的提交哈希值,通过git checkout -b <new-branch> <commit-hash>
命令创建一个新分支。
Git中如何管理子模块(Submodules)?
Git子模块的管理包括以下步骤:
1、添加子模块: 使用git submodule add <repository> <path>
命令将子模块添加到仓库中。
2、初始化子模块: 在克隆包含子模块的仓库后,运行git submodule init
初始化子模块。
3、更新子模块: 使用git submodule update
命令获取子模块的最新更改。
4、管理子模块的更改: 子模块的更改需要在其自己的仓库中管理,并且需要在主仓库中更新子模块的引用。
Git中如何撤销已推送到远程仓库的提交?
撤销已推送到远程仓库的提交可以通过以下步骤完成:
1、撤销最近的提交: 使用git revert HEAD
创建一个新的提交,它将撤销最近的一次提交。
2、强制推送更改: 如果需要完全移除提交历史,可以使用git push --force
,但这是一个危险操作,可能会影响所有协作者。
Git中如何使用交互式rebase?
交互式rebase在Git中的使用方法如下:
1、启动交互式rebase: 使用git rebase -i <commit-hash>
开始交互式rebase,其中<commit-hash>
是要修改的提交之前的提交。
2、选择操作: 在交互式编辑器中,可以选择对每个提交执行的操作,如“pick”,“reword”,“edit”,“squash”,“fixup”等。
3、应用更改: 完成选择后,Git会重新应用这些提交,并根据选择进行相应的操作。
Git中的bisect命令如何使用,它的用途是什么?
Git中的bisect
命令用于快速定位引入错误的提交。使用方法如下:
1、开始二分查找: 使用git bisect start
开始。
2、标记好的提交和坏的提交: 使用git bisect good <commit-hash>
标记没有问题的提交,使用git bisect bad <commit-hash>
标记有问题的提交。
3、Git自动检查: Git会自动检出中间的提交供测试,直到找到引入问题的提交。
4、结束查找: 一旦找到问题提交,使用git bisect reset
结束查找。
Git Hooks中如何提高开发效率?
Git Hooks可以在不同的Git事件触发时运行自定义脚本,提高开发效率:
1、配置Hooks: Git仓库中的.git/hooks
目录包含多种钩子脚本,如pre-commit
、post-commit
等。
2、自定义脚本: 可以编写自定义脚本并放在相应的钩子文件中,比如在pre-commit
钩子中运行代码质量检查。
3、自动化任务: 钩子可以用来自动化各种任务,例如自动运行测试、代码格式化、发送通知等。
Git中如何创建和管理远程分支?
在Git中创建和管理远程分支的步骤包括:
1、创建本地分支: 首先使用git checkout -b <branch-name>
创建一个新的本地分支。
2、推送到远程仓库: 使用git push -u origin <branch-name>
将该分支推送到远程仓库。-u
参数设置上游分支,以便将来跟踪。
3、检出远程分支: 使用git checkout -b <branch-name> origin/<branch-name>
来检出一个远程分支。
4、删除远程分支: 使用git push origin --delete <branch-name>
来删除一个远程分支。
Git中如何使用rebase解决冲突?
使用Git rebase解决冲突的步骤如下:
1、开始rebase: 使用git rebase <base-branch>
开始变基操作。
2、解决冲突: 如果出现冲突,Git会暂停rebase。此时需要手动解决这些冲突。
3、继续rebase: 解决冲突后,使用git add <file>
将解决后的文件标记为已解决,然后使用git rebase --continue
继续rebase过程。
4、如果需要中断rebase: 可以使用git rebase --abort
来取消rebase操作并恢复到原始状态。
如何使用Git进行代码审查(Code Review)?
使用Git进行代码审查的流程包括:
1、创建拉取请求(Pull Request): 开发者应该在完成功能开发后,从他们的功能分支创建一个拉取请求到主分支。
2、进行代码审查: 团队成员可以在拉取请求中审查代码变更,提出建议或请求更改。
3、讨论和修改: 开发者根据反馈进行必要的讨论和修改。
4、合并代码: 完成审查后,如果代码满足标准,可以将更改合并到主分支。
Git中的标签(Tag)和分支(Branch)有什么区别?
Git中标签和分支的主要区别在于它们的用途和特性:
1、用途区别: 分支用于日常开发,允许开发者在隔离的环境中工作;而标签通常用于标记特定的版本,如发布或重要的里程碑。
2、动态与静态: 分支是动态的,随着新的提交而变化;标签是静态的,它们指向特定的提交,不随后续提交而变化。
3、常用操作: 开发者经常在不同的分支间切换和合并;而标签一旦创建,通常就不再修改。
Git中的rebase
操作与merge
操作有何不同?
rebase
和merge
都是Git中用于整合不同分支改动的命令,但它们的工作方式和结果有所不同:
1、工作流程: merge
将两个分支的最新快照(HEAD)以及二者最近的共同祖先合并,创建一个新的提交。而rebase
则是将一个分支的所有改动应用到另一个分支上。
2、历史记录: merge
会保留所有分支的历史记录,而rebase
会重新写历史,创建一系列新的提交。
3、结果清晰度: 使用rebase
通常会得到更加线性、清晰的项目历史,但它可能改变历史记录。而merge
保留了原始历史,但可能导致复杂的分支结构。
Git中,如何撤销已经推送到远程仓库的提交?
撤销已经推送到远程仓库的提交可以通过以下方法:
1、使用git revert
: git revert
会创建一个新的提交,这个提交是对之前提交的撤销。这是一种安全的方法,因为它不会改变项目历史。
2、使用git reset
: 如果你想要完全移除某个提交,可以在本地使用git reset
,然后使用git push --force
强制推送。但这种方法会改变历史,对其他协作者可能造成影响。
Git中的stash
命令及其用途。
Git的stash
命令用于临时保存你的工作目录中的改动:
1、保存工作进度: 当你正在进行一个工作但需要临时切换到其他分支处理事务时,可以使用stash
保存当前进度。
2、恢复改动: 之后你可以使用git stash pop
或git stash apply
来恢复这些改动。
3、多次储存: git stash
允许你多次储存工作进度,并通过git stash list
查看。
Git中的cherry-pick
命令是用来做什么的?
cherry-pick
命令在Git中用于选择并应用某个分支上的一个或多个提交到当前分支:
1、选择性合并提交: 当你只想从另一个分支合并特定的提交而不是整个分支时,cherry-pick
是一个有用的工具。
2、避免冲突: 在某些情况下,它可以帮助解决合并冲突,通过逐个应用提交来处理。
Git中如何解决合并时的冲突?
解决Git合并冲突的步骤包括:
1、识别冲突: 首先,Git会标记出产生冲突的文件。
2、手动编辑: 打开这些文件,查找冲突标记(如<<<<<<<
, =======
, >>>>>>>
),并决定保留哪些改动。
3、标记为已解决: 编辑后,使用git add
命令将它们标记为已解决。
4、完成合并: 一旦解决所有冲突,就可以继续合并过程,完成后提交。
Git中的fetch
和pull
命令有什么区别?
fetch
和pull
是Git中用于从远程仓库获取数据的两个不同命令,它们的主要区别在于:
1、获取数据: git fetch
仅仅下载远程仓库的最新数据到本地,不会自动合并或修改你的工作。它允许你手动查看变更后再决定是否合并。
2、自动合并: git pull
则是git fetch
和git merge
的组合。它不仅下载数据,还会自动将远程分支的变更合并到当前分支。
3、使用场景: 如果你想先审查变更再合并,使用fetch
更合适;如果你信任这些变更且希望自动合并,使用pull
更方便。
Git中的HEAD
、index
和working directory
分别是什么?
在Git中,HEAD
、index
(暂存区)和working directory
(工作目录)是三个关键的概念:
1、HEAD: HEAD
指向当前分支上最后一次提交的快照,它是一个指针,通常指向分支名称(如master
)。
2、index(暂存区): 当你执行git add
命令时,改动会被放入暂存区。暂存区是一个准备好的下一次提交的内容的区域。
3、working directory: 工作目录包含项目的文件。这里的文件是你实际工作的,可以修改的。工作目录的改动还未被记录到Git的历史中。
Git如何实现版本控制的?
Git实现版本控制的方式基于以下几个核心机制:
1、快照系统: Git不是按文件变更差异来存储数据的,而是通过存储项目状态的快照。每次提交,Git都会保存一个项目状态的快照。
2、分支: Git的分支是轻量级的。它们仅仅是指向特定提交的指针。这使得在不同的开发线路上工作变得非常容易和快速。
3、合并和重组: Git提供了强大的合并和重组功能,允许从不同的分支和时间点整合代码。
Git中的tag
功能及其用途。
在Git中,tag
功能用于给特定的提交版本打上标记:
1、版本发布: 标签通常用于发布版本号(如v1.0、v2.0),这样可以方便地追踪特定的版本。
2、轻量标签和附注标签: Git有两种类型的标签:轻量标签(lightweight)是指向提交的引用;附注标签(annotated)则是存储在Git数据库中的完整对象,它包括签名者信息、日期和消息。
3、检出标签: 可以用git checkout
来检出特定的标签,回到那个版本的状态。
Git中的merge
和rebase
操作有什么区别?
Git中merge
和rebase
的主要区别如下:
1、提交历史: merge
会保留所有分支的提交历史,而rebase
则会创建一系列新的提交,使得历史看起来像一条直线。
2、冲突解决: 在merge
中,冲突是在合并的最后一步解决的。而在rebase
中,冲突需要在每个被重新应用的提交中解决。
3、适用场景: merge
适用于需要保留分支结构的场景,而rebase
适用于想要简化项目历史的场景。
Git中的HEAD、工作树和索引之间有什么关系?
Git中HEAD、工作树和索引之间的关系:
1、HEAD: 表示当前分支的最新提交。
2、工作树: 是项目的一个工作副本,包含了当前分支的所有文件。
3、索引: 又称暂存区,是一个中介区域,用于记录工作树中即将被提交的改动。
Git中的快进(Fast-forward)和非快进(Non-fast-forward)合并的区别。
快进(Fast-forward)和非快进(Non-fast-forward)合并的区别:
1、快进合并: 发生在被合并分支的所有提交都在当前分支的直接上游时。在快进合并中,分支指针只是简单地向前移动。
2、非快进合并: 当被合并分支有当前分支没有的新提交时,会创建一个新的提交来合并两个分支的历史。
Git中的stash
操作是用来做什么的?如何正确使用它?
stash
操作在Git中的用途和正确使用方法:
1、用途: stash
用于临时保存当前工作目录和索引的状态,让你可以干净地切换到其他分支。
2、使用方法: 使用git stash
保存改动,使用git stash pop
应用最近的存储,或者使用git stash apply
应用指定的stash。
Git中如何解决分支合并中的冲突?
解决Git分支合并冲突的步骤:
1、标识冲突: 在合并过程中,Git会标识出冲突的文件。
2、手动解决冲突: 打开冲突文件,查找冲突标记(例如<<<<<<<
、=======
、>>>>>>>
),手动解决这些冲突。
3、标记为已解决: 解决完冲突后,使用git add
命令将文件标记为已解决。
4、完成合并: 使用git commit
完成合并操作。
Git中的分布式版本控制系统与集中式版本控制系统有什么不同?
Git作为一个分布式版本控制系统(DVCS),与传统的集中式版本控制系统(CVCS)如SVN的主要区别在于:
1、存储方式: 在DVCS中,每个开发者的机器上都有完整的仓库副本,包括项目的完整历史记录。而在CVCS中,历史记录通常只存在于中央服务器上。
2、网络依赖性: 由于DVCS中每个开发者都有完整的仓库,因此可以在本地进行多数操作,包括提交、分支和合并,而无需网络连接。相反,CVCS需要频繁地与中央服务器交互。
3、数据安全性和可靠性: 在DVCS中,每个开发者的机器都是一个数据备份点,这提高了数据的安全性和可靠性。而在CVCS中,中央服务器的损坏可能导致数据丢失。
4、分支处理: Git支持轻量级的分支创建和合并,这使得分支操作更加快速和灵活。在许多CVCS中,分支操作可能更加笨重和耗时。
5、合作方式: Git的分布式特性使得开发者之间的合作更加灵活,可以选择多种不同的工作流程来适应团队的需求。
Git中如何解决冲突,并提供一个具体的操作示例。
在Git中解决冲突通常涉及以下步骤:
1、识别冲突: 当合并分支时,如果同一个文件的同一个部分被不同的提交所修改,Git会标记这个文件为冲突状态。
2、手动编辑文件: 开发者需要打开冲突的文件,并查找由**<<<<<<<、=======、>>>>>>>**标记的区域。这些标记之间的内容分别代表不同分支的修改。
3、修改冲突部分: 开发者根据实际需要决定保留哪些修改,或者合并这些修改。
4、添加和提交更改: 解决冲突后,使用git add <文件名>来标记冲突已解决。然后,执行git commit来提交合并。
示例操作:
git merge feature-branch
# 假设出现冲突
# 打开冲突文件,手动解决冲突
git add conflicted-file.txt
git commit -m "Resolved merge conflict by integrating changes from feature-branch"
Git中的rebase与merge有什么区别?
rebase和merge是Git中两种不同的分支整合方法,它们有以下主要区别:
1、提交历史的呈现: merge会保留所有分支的历史,而rebase则会创建一条线性的历史。rebase通过重新应用更改到另一个分支,可以产生更干净、直线的历史记录。
2、冲突处理: 在rebase过程中,每次应用单个提交时都可能遇到冲突,需要即时解决。而merge是一次性合并所有更改,可能一次解决所有冲突。
3、回溯方便性: 因为merge保留原始分支结构,所以更容易理解分支间的关系和更改。rebase则可能使跟踪更改的来源变得更加困难。
4、风险性: rebase可以改变提交的哈希值,这可能对共享分支造成影响。因此,在共享分支上使用rebase需要小心。
Git中优化大仓库的性能?
在Git中优化大型仓库的性能可以通过以下方法:
1、使用浅克隆: 使用git clone --depth 1命令可以创建一个只包含最近一次提交的浅克隆。这减少了下载的数据量。
2、利用Git Large File Storage(LFS): Git LFS允许将大文件存储在单独的服务器上,而不是直接在仓库中。这可以减少克隆和提取大仓库的时间。
3、定期清理仓库: 使用git gc命令可以压缩仓库大小,清理不必要的文件,优化本地仓库的性能。
4、有选择性地检出: 使用git sparse-checkout命令可以只检出需要的文件或目录,减少不必要的数据加载。
5、使用引用存储库: 如果有多个相似的仓库,可以使用git clone --reference来共享它们的数据,减少重复数据的存储。
Git中的cherry-pick命令是什么,以及如何使用它?
cherry-pick命令在Git中用于将一个分支上的单个提交应用到当前分支。它的使用场景包括:
1、选择性地应用提交: 如果只想将特定的提交从一个分支移动到另一个分支,而不合并整个分支,可以使用cherry-pick。
2、修复错误: 当错误被修复在一个分支上,而另一个分支也需要这个修复时,可以使用cherry-pick来应用该修复。
使用方法:
首先,找到想要cherry-pick的提交的哈希值。然后,在目标分支上执行如下命令:
git cherry-pick <commit-hash>
如果出现冲突,需要手动解决,然后继续完成cherry-pick操作。
- 感谢你赐予我前进的力量