当前位置: 首页 > wzjs >正文

做美食网站的素材郑州外贸网站推广

做美食网站的素材,郑州外贸网站推广,美食网站开发报告,wordpress 友情连接git reset:重置分支的历史与工作区​ 核心作用​​:移动当前分支的指针(即改变分支的历史),并可选地修改暂存区(Index)和工作目录(Working Directory)。常用于撤销提交或…

git reset:重置分支的历史与工作区​

核心作用​​:移动当前分支的指针(即改变分支的历史),并可选地修改暂存区(Index)和工作目录(Working Directory)。常用于撤销提交或合并操作。

三种模式​
  1. ​​--soft 模式​
    行为​
    ​:仅移动分支指针(HEAD),不修改暂存区和工作目录。
    ​使用场景​​:撤销提交但保留修改,允许重新提交。

    git reset --soft HEAD~1  # 撤销最后一次提交,修改保留在暂存区
  2. ​​--mixed 模式(默认)
    行为​​:移动分支指针,并重置暂存区,但保留工作目录的修改。
    使用场景​​:撤销提交和暂存操作,需重新 add 后再提交
    git reset HEAD~1  # 等效于 git reset --mixed HEAD~1
  3. ​​--hard 模式
    行为​​:移动分支指针,并强制重置暂存区和工作目录到指定提交的状态。
    使用场景​​:彻底丢弃最近的提交和所有修改(慎用!)。
    git reset --hard HEAD~1  # 丢弃最后一次提交及所有修改
    关键特点​
    影响分支历史​​:reset 会改变分支的指针,从而修改提交历史。
    ​适用场景​​:撤销本地提交、合并冲突后重置等操作。

git checkout:切换分支或检出内容​

核心作用​​:切换分支,或检出指定提交/文件到工作目录。​​不修改分支历史​​,主要用于切换上下文或恢复文件。

切换分支​
git checkout <branch-name>  # 切换到另一个分支
    • 行为​​:
      • 移动 HEAD 到目标分支,更新工作目录和暂存区为该分支的最新状态。
      • 如果工作目录有未提交的修改,Git 会阻止切换(除非使用 -f 强制切换或修改被忽略)。

    分离头指针(Detached HEAD)​​ 

    git checkout <commit-hash>  # 检出一个提交,进入分离头状态
    • 行为​​:
      • HEAD 直接指向提交而非分支,此时的新提交不会属于任何分支(需手动创建分支保存)。
      • 适用于临时调试或实验性修改。
    检出文件
    git checkout HEAD -- file.txt  # 从 HEAD 恢复文件到工作目录和暂存区
    git checkout <branch> -- file.txt  # 从其他分支恢复文件
    • 行为​​:
      • 将指定文件恢复到目标版本(覆盖工作目录和暂存区),不影响 HEAD 位置。
      • 常用于撤销对单个文件的修改。
    关键特点​
    • ​不修改分支历史​​:checkout 仅切换上下文或恢复文件,不会改变分支的提交记录。
    • ​适用场景​​:切换分支、临时查看旧版本代码、撤销文件修改。

    reset 与 checkout 的核心区别​

    功能​git resetgit checkout
    ​操作对象​当前分支(修改分支指针)分支、提交或文件(不修改分支历史)
    ​影响范围​分支历史、暂存区、工作目录工作目录、暂存区(仅文件操作时)
    ​是否改变提交历史​否(除非在分离头模式下提交)
    ​典型场景​撤销本地提交切换分支、恢复文件

    总结​

    • ​用 reset 当你想撤销提交或修改分支历史​​(如回退到旧版本)。
    • ​用 checkout 当你想切换分支、查看旧版本代码,或恢复单个文件​​。

    ​慎用 git reset --hard​:它会永久丢弃未提交的修改!


    场景:需要将工作目录的修改与上一个提交​​完全合并为一个新提交​​,并可能修改提交信息,怎么做呢?

    以下是分步解决方案,可根据你的需求选择两种方法:

    git reset --soft 和 git commit --amend ​​都是对本地提交历史的修改​​。如果这些提交已经推送到远程仓库(如 GitHub、GitLab),直接修改本地历史后,再推送会遇到问题。如果提交已推送到远程仓库需要告知团队成员


    ​方法一:使用 git reset --soft

    适用场景​​:需要将工作目录的修改与上一个提交​​完全合并为一个新提交​​,并可能修改提交信息。

    步骤​​:

    • ​​撤销最近一次提交,但保留修改在暂存区​​
    git reset --soft HEAD~1

      此时,之前的提交内容和工作目录的新修改都会保留在暂存区(git status 会显示所有修改已暂存)。

      • 查看状态确认修改已合并​
      git status  # 确认所有修改已加入暂存区
      • ​提交合并后的内容​
      git commit -m "合并工作区修改与上一个提交"

      方法二:使用 git commit --amend 

      适用场景​​:仅需将工作目录的修改​​追加到上一个提交​​,且不修改提交信息(或微调)。

      步骤​​:

      • ​将工作目录的修改加入暂存区​​:
      git add .  # 或指定文件 git add file1.txt
      • ​将修改合并到上一个提交​​:
      git commit --amend --no-edit  # 保留原提交信息

      ​ 如果想修改提交信息,去掉 --no-edit

      git commit --amend -m "新的提交信息"
        ​方法​git reset --softgit commit --amend
        ​是否修改提交历史​是(生成新提交)是(覆盖原提交)
        ​是否保留原提交信息​需手动输入新提交信息可保留或修改原提交信息
        ​适用场景​完全重写提交内容与信息快速追加修改到原提交

        http://www.dtcms.com/wzjs/419769.html

        相关文章:

      • python做网站验证码网络营销sem培训
      • 企业网站 设计国外网站建设
      • 罗湖做网站哪家好网站运营专员
      • 网站建设都是模板seo网站优化技术
      • 深圳福永做网站韩国搜索引擎排名
      • 台州网站建设团队宁波网站推广公司价格
      • 深圳网站开发招聘有产品怎么找销售渠道
      • 湖南微信网站公司电话号码推广哪个平台好
      • 团购网站做二级域名站长工具外链查询
      • 网站建设需多少钱广告资源网
      • 做药物分析网站的网站建设
      • 制作网站的手机软件南昌搜索引擎优化
      • thinkphp5网站开发如何在各种网站投放广告
      • 河南专业网站建设公司推荐刷网站seo排名软件
      • 广州腾虎网络网站建设熊掌号深圳推广平台有哪些
      • 溧阳网站定制宣传链接怎么做
      • 免费网站统计二级分销小程序
      • 整形医院网站制作网站建设加推广优化
      • 网站营销与推广策略有哪些网络推广平台
      • 网站建设哪些公司yandex搜索引擎入口
      • 网站开发遇到的最大困难免费个人网站建站申请
      • 资阳地网站seo百度快速提交入口
      • 网站地图xml文件百度推广怎么弄
      • 文库网站建设开发宁波seo推广优化公司
      • 大型网站开发费用推广普通话作文
      • 怎么用ppt做网站最新新闻热点
      • 海外信息流推广怎么做重庆seo的薪酬水平
      • 网站信息化建设什么意思关于seo如何优化
      • 自建站和独立站一样吗批量查询收录
      • 小的电商网站手机软文广告300字