switch、case语句:

点击查看代码
int state = 1;
switch(state)
{
case 1:
{
//状态1执行的程序
}
case 2:
{
//状态2执行的程序
}
defalt:
{
//默认执行的程序
}
}

在工作过程当中的一个switch case语句为:

点击查看代码
UINT CCS2X90_HHU_DirectUpgradeDlg::UpgradeThread(LPVOID pParam)
{
std::string logFilePath = "C:\\Users\\Administrator\\Desktop\\项目文件\\BootLoader 错误注入测试项目\\上位机源码\\CS2X90_HHU_DirectUpgrade\\Fault_Injection_Test_Log.txt";
std::ofstream logFile(logFilePath);
if (!logFile.is_open())
{
std::cerr << "无法打开日志文件: " << logFilePath.c_str() << std::endl;
}
TeeStream teeStream(std::cout, logFile); BOOL m_IsUpgrading = TRUE;
UpgradeState_For_HHU_Device state = HHU_COM_TEST_STAGE_GET_BIOS; BYTE Cmd[10] = { 0 };
BYTE rbuf[50] = { 0 };
BYTE UpgradeStep = 0;
UINT16 rcr_result = 0;
UINT rLen = 0, tryCnt = 0;
UINT preTime = 0;
CString VersionStr = "";
UINT32 frameSending = 0;
UINT8 Data[258] = { 0 };
BOOL CS3290_rflag = FALSE;
CCS2X90_HHU_DirectUpgradeDlg* pInstance = (CCS2X90_HHU_DirectUpgradeDlg*)pParam; while (m_IsUpgrading)
{
//std::cout << "开始外循环" << std::endl; //用于检测串口设备是否开启,只会在程序开始前执行一次,之后程序就会卡在while (m_ThreadRunFlag)当中了
if (m_ThreadRunFlag)
{
std::cout << "正在检测串口设备是否开启" << std::endl;
if (!pInstance->m_ComDevice.OpenDevice(pInstance->m_PortName, 115200))
{
std::cout << "串口设备开启失败" << std::endl;
pInstance->AddToInfOut(pInstance->m_Info.OpenDeviceErrorInfo());
pInstance->GetDlgItem(IDC_COMBO_PORTNAME)->EnableWindow(TRUE);
pInstance->GetDlgItem(IDC_BUTTON_UPGRADE)->EnableWindow(TRUE);
return 0;
}
std::cout << "串口设备开启成功" << std::endl;
} //开始进行升级循环
while (m_ThreadRunFlag)
{
//std::cout << "开始内循环" << std::endl; //只要任意条件满足,则进行读取设备上发数据的操作
//在此处不断的读取数据到rbuf当中,用于后续的判断
if ((m_IsCS3290 == FALSE) || (CS3290_rflag == TRUE))
{
memset(rbuf, 0, sizeof(rbuf));
do
{
std::cout << "读取设备返回数据" << std::endl;
rLen = pInstance->m_ComDevice.ReadDevice(rbuf, 1);
if ((UpgradeStep == 6) && (((GetTickCount() - preTime) > 30000) || (rLen != 0)))
break;
} while (UpgradeStep == 6);
}
//如果任意条件都不满足
else
{
if (UpgradeStep == 0)
{
std::cout << "正在判断上位机控件选择的升级模式" << std::endl;
if (((CButton*)pInstance->GetDlgItem(IDC_RADIO_LOADER))->GetCheck())
{
Cmd[0] = RS232_UPGRADE_HHUINT_LDR;
std::cout << "选择了Lodaer升级模式" << std::endl;
}
else if (((CButton*)pInstance->GetDlgItem(IDC_RADIO_APP))->GetCheck())
{
Cmd[0] = RS232_UPGRADE_HHUINT_APP;
std::cout << "选择了APP升级模式" << std::endl;
} std::cout << "发送升级模式指令" << std::endl;
pInstance->m_ComDevice.WriteDevice(Cmd, 1);
UpgradeStep = 1;
CS3290_rflag = TRUE;
continue;
}
} //程序状态进行回滚,将升级流程恢复到初始状态
if (m_IsCS3290 == FALSE && pInstance->m_AutoUpgrade == FALSE && flag == TRUE && UpgradeStep == 0)
{
std::cout << "程序状态进行回滚,将升级流程恢复到初始状态" << std::endl;
flag = FALSE;
pInstance->GetDlgItem(IDC_COMBO_PORTNAME)->EnableWindow(TRUE);
pInstance->GetDlgItem(IDC_BUTTON_UPGRADE)->EnableWindow(TRUE);
pInstance->m_File.CloseFile();
pInstance->m_ComDevice.SetBaudRate(115200);
pInstance->m_ComDevice.CloseDevice();
return 0;
} switch (state)
{ //获取BIOS信息
case HHU_COM_TEST_STAGE_GET_BIOS:
{
std::cout << "开始进行获取BIOS的阶段" << std::endl;
switch (rbuf[0])
{
case RS232_UPGRADE_RQ: // 处理升级请求, //最开始的升级步骤为0
{
if (UpgradeStep == 0)
{
std::cout << "收到了“0x05”且升级流程状态为0" << std::endl;
std::cout << "发送“0x06”,用以回应设备" << std::endl;
Cmd[0] = RS232_UPGRADE_CF;
pInstance->m_ComDevice.WriteDevice(Cmd, 1);
Sleep(500); std::cout << "开始根据上位机选择的升级模式发送对应的指令" << std::endl;
if (((CButton*)pInstance->GetDlgItem(IDC_RADIO_LOADER))->GetCheck())
{
Cmd[0] = RS232_UPGRADE_HHUINT_LDR;
std::cout << "选择Loader模式,发送“0xAA”" << std::endl;
}
else if (((CButton*)pInstance->GetDlgItem(IDC_RADIO_APP))->GetCheck())
{
Cmd[0] = RS232_UPGRADE_HHUINT_APP;
std::cout << "选择APP模式,发送“0xBB”" << std::endl;
} pInstance->m_ComDevice.WriteDevice(Cmd, 1); if ((pInstance->m_AutoUpgrade) && (m_IsCS3290 == FALSE))
{
pInstance->SetDlgItemText(IDC_EDIT_DISPLAY, "");
pInstance->m_UpgradeProgress.SetPos(0);
pInstance->m_UpgradeProgress.SetBarColor(RGB(0, 0, 255));
}
//设置升级步骤1
UpgradeStep = 1;
std::cout << "设置升级步骤1" << std::endl;
}
break;
} case RS232_UPGRADE_ACK: // 处理升级应答
{
switch (UpgradeStep)
{
case 1:
{
if (((CButton*)pInstance->GetDlgItem(IDC_RADIO_APP))->GetCheck())
{
Sleep(500);
}
std::cout << "发送BIOS版本信息查询指令“0x30”" << std::endl;
Cmd[0] = RS232_REQ_VER;
pInstance->m_ComDevice.WriteDevice(Cmd, 1); rLen = pInstance->m_ComDevice.ReadDevice(rbuf, 30);
VersionStr += pInstance->m_Info.BiosVersionInfo();
std::cout << "开始接受BIOS信息" << std::endl;
for (UINT i = 0; i < rLen; i++)
{
VersionStr += rbuf[i];
}
std::cout << "BIOS" << (LPCSTR)VersionStr << std::endl;
std::cout << "-----------------------------------------------------------------------------------------------------------------------------------------------------------" << std::endl;
std::cout << "" << std::endl;
teeStream << "【Bootloader Upgrade(Fault Injection Test)测试】" << std::endl;
teeStream << "无线串口RS232快速升级" << std::endl;
teeStream << "BIOS" << (LPCSTR)VersionStr << std::endl;
teeStream << "-----------------------------------------------------------------------------------------------------------------------------------------------------------" << std::endl;
teeStream << "" << std::endl;
pInstance->AddToInfOut(VersionStr + "\r\n");
UpgradeStep = 0;
state = HHU_COM_NORMAL_STAGE_1;
std::cout << "state状态变化为HHU_COM_NORMAL_STAGE_1" << std::endl;
Sleep(20000);
break;
}
}
break;
} default: // 当 rbuf[0] 不匹配任何 case 时执行
{
std::cout << "未收到预期的返回数据,保持状态为 HHU_COM_TEST_STAGE_GET_BIOS" << std::endl;
state = HHU_COM_TEST_STAGE_GET_BIOS;
break;
}
} //end of "switch (rbuf[0])"
break;
}//end of "case HHU_COM_TEST_STAGE_GET_BIOS:" //明明没有满足这个条件,但是还是会自动执行到HHU_COM_TEST_STAGE_1这个状态 //测试阶段1,此处属于握手阶段的异常测试项,发送“0xFF”,等待2分钟,只要设备没有任何响应就是符合预期的现象。此时通过上位机窗口提升用户重启设备进行之后的测试
case HHU_COM_TEST_STAGE_1:
{ std::cout << "测试阶段1:握手阶段异常测试,发送“0xFF”,等待2分钟,只要设备没有任何响应就是符合预期的现象。此时通过上位机窗口提升用户重启设备进行之后的测试" << std::endl; } //正常阶段1,一直顺序执行,直到测试项来到设置设备的波特率
case HHU_COM_NORMAL_STAGE_1:
{
std::cout << "正常阶段1" << std::endl;
} } //end of switch } //end of "while (m_ThreadRunFlag)" 内循环 }//end of "while (m_IsUpgrading)" 外循环 return 0;
}

其中case HHU_COM_TEST_STAGE_GET_BIOS:中的switch在实际编写的过程当中出了问题,如果需要跳出这个case语句,其中的break需要放在case语句最外层括号的内部,具体如下:

点击查看代码
//获取BIOS信息
case HHU_COM_TEST_STAGE_GET_BIOS:
{
std::cout << "开始进行获取BIOS的阶段" << std::endl;
switch (rbuf[0])
{
case RS232_UPGRADE_RQ: // 处理升级请求, //最开始的升级步骤为0
{ break;
} case RS232_UPGRADE_ACK: // 处理升级应答
{
switch (UpgradeStep)
{
case 1:
{
break;
}
}
break;
} default: // 当 rbuf[0] 不匹配任何 case 时执行
{
std::cout << "未收到预期的返回数据,保持状态为 HHU_COM_TEST_STAGE_GET_BIOS" << std::endl;
state = HHU_COM_TEST_STAGE_GET_BIOS;
break;
}
} //end of "switch (rbuf[0])"
break;
}//end of "case HHU_COM_TEST_STAGE_GET_BIOS:"

这样才是正确的,即break放在case语句右括号之前

switch、case语句的问题的更多相关文章

  1. 为什么说在使用多条件判断时switch case语句比if语句效率高?

    在学习JavaScript中的if控制语句和switch控制语句的时候,提到了使用多条件判断时switch case语句比if语句效率高,但是身为小白的我并没有在代码中看出有什么不同.去度娘找了半个小 ...

  2. java中的Switch case语句

    java中的Switch case 语句 在Switch语句中有4个关键字:switch,case break,default. 在switch(变量),变量只能是整型或者字符型,程序先读出这个变量的 ...

  3. switch… case 语句的用法

    switch… case 语句的用法   public class Test7 { public static void main(String[] args) { int i=5; switch(i ...

  4. if语句,if...else if语句和switch...case语句的区别和分析

    前段时间在工作中遇到了一个关于条件判断语句的问题,在if语句,if else if语句和switch case语句这三者之间分析,使用其中最有效率的一种方法. 所以就将这个问题作为自己第一篇博客的主要 ...

  5. Python | 基础系列 · Python为什么没有switch/case语句?

    与我之前使用的所有语言都不同,Python没有switch/case语句.为了达到这种分支语句的效果,一般方法是使用字典映射: def numbers_to_strings(argument): sw ...

  6. 为什么switch...case语句比if...else执行效率高

    在C语言中,教科书告诉我们switch...case...语句比if...else if...else执行效率要高,但这到底是为什么呢?本文尝试从汇编的角度予以分析并揭晓其中的奥秘. 第一步,写一个d ...

  7. JavaScript基础知识(if、if else、else if、while、switch...case语句)

    13.语句 概念:就是分号(:) 代表一条语句的结束 习惯:一行只编写一条语句:一行编写多条语句(代码可读性较差) 语句块:可以包含多条语句     "{ }"将多条语句包裹 u ...

  8. C语言中switch case语句可变参实现方法(case 参数 空格...空格 参数 :)

    正常情况下,switch case语句是这么写的: : : ... ;break ; default : ... ;break ; } 接下来说一种不常见的,但是对于多参数有很大的帮助的写法: 先给一 ...

  9. Java基础之循环语句、条件语句、switch case 语句

    Java 循环结构 - for, while 及 do...while 顺序结构的程序语句只能被执行一次.如果您想要同样的操作执行多次,,就需要使用循环结构. Java中有三种主要的循环结构: whi ...

  10. python技巧 switch case语句

    不同于C语言和SHELL,python中没有switch case语句,关于为什么没有,官方的解释是这样的 使用Python模拟实现的方法: def switch_if(fun, x, y):    ...

随机推荐

  1. 组长:你熟悉过React,开发个Next项目模板吧,我:怎么扯上关系的?

    组长:你熟悉过React,开发个Next项目模板吧,我:怎么扯上关系的? 最近工作安排我开发一个Next.js项目模板,心里默笑,React用得少得都快忘光了,现在得搞Next?虽然我曾是React的 ...

  2. vba for excel 随笔

    q1: excel 没有vba入口 1. 快捷键:Alt + F11 2.调出开发工具 1. 打开文件后,依次点击菜单项[文件]-[选项]: 2.在"Excel"选项界面中点击左侧 ...

  3. Apple Silicon 芯片 Mac 在 x86_64 模式下启动 Kettle

    苹果于 2020 年推出了自家设计的基于 ARM 架构的 M1 芯片,在日常生活的大部分使用过程中,M1 的体验很好.然而,依然存在一小部分软件无法兼容 ARM 架构,需要我们模拟 x86 的架构来运 ...

  4. YAML 使用

    YAML 语言教程 | 阮一峰的网络日志 YAML Reference YAML Tutorial | Tutorials Point YAML (/ˈjæməl/) YAML Ain't Marku ...

  5. uniCloud 云开发Dome

    实现账号密码登录,注册, 信息图片上传与查看 项目地址:https://gitee.com/jielov/uni-cloud_development 先创建云服务空间 与云函数 可参考 https:/ ...

  6. PlugIR:开源还不用微调,首尔大学提出即插即用的多轮对话图文检索 | ACL 2024

    即插即用的PlugIR通过LLM提问者和用户之间的对话逐步改进文本查询以进行图像检索,然后利用LLM将对话转换为检索模型更易理解的格式(一句话).首先,通过重新构造对话形式上下文消除了在现有视觉对话数 ...

  7. python项目生成exe

    前言 做了个python的小项目,需要打包为桌面端的exe使用,结果一打包,体积直接上百兆了,研究了下,使用虚拟环境打出的包会更干净小巧. 安装anaconda anaconda用作python的虚拟 ...

  8. 【YashanDB知识库】数据变化率超过阈值统计信息失效

    [问题分类]性能优化 [关键字]统计信息 [问题描述] SQL --创建表结构 drop table t1; create table t1 (id int,name varchar2(200)); ...

  9. Angular 18+ 高级教程 – Component 组件 の Query Elements

    前言 Angular 是 MVVM 框架. MVVM 的宗旨是 "不要直接操作 DOM". 在 Component 组件 の Template Binding Syntax 文章中 ...

  10. 从0到1搭建权限管理系统系列三 .net8 JWT创建Token并使用

    说明 该文章是属于OverallAuth2.0系列文章,每周更新一篇该系列文章(从0到1完成系统开发). 该系统文章,我会尽量说的非常详细,做到不管新手.老手都能看懂. 说明:OverallAuth2 ...