switch、case语句的问题
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语句的问题的更多相关文章
- 为什么说在使用多条件判断时switch case语句比if语句效率高?
在学习JavaScript中的if控制语句和switch控制语句的时候,提到了使用多条件判断时switch case语句比if语句效率高,但是身为小白的我并没有在代码中看出有什么不同.去度娘找了半个小 ...
- java中的Switch case语句
java中的Switch case 语句 在Switch语句中有4个关键字:switch,case break,default. 在switch(变量),变量只能是整型或者字符型,程序先读出这个变量的 ...
- switch… case 语句的用法
switch… case 语句的用法 public class Test7 { public static void main(String[] args) { int i=5; switch(i ...
- if语句,if...else if语句和switch...case语句的区别和分析
前段时间在工作中遇到了一个关于条件判断语句的问题,在if语句,if else if语句和switch case语句这三者之间分析,使用其中最有效率的一种方法. 所以就将这个问题作为自己第一篇博客的主要 ...
- Python | 基础系列 · Python为什么没有switch/case语句?
与我之前使用的所有语言都不同,Python没有switch/case语句.为了达到这种分支语句的效果,一般方法是使用字典映射: def numbers_to_strings(argument): sw ...
- 为什么switch...case语句比if...else执行效率高
在C语言中,教科书告诉我们switch...case...语句比if...else if...else执行效率要高,但这到底是为什么呢?本文尝试从汇编的角度予以分析并揭晓其中的奥秘. 第一步,写一个d ...
- JavaScript基础知识(if、if else、else if、while、switch...case语句)
13.语句 概念:就是分号(:) 代表一条语句的结束 习惯:一行只编写一条语句:一行编写多条语句(代码可读性较差) 语句块:可以包含多条语句 "{ }"将多条语句包裹 u ...
- C语言中switch case语句可变参实现方法(case 参数 空格...空格 参数 :)
正常情况下,switch case语句是这么写的: : : ... ;break ; default : ... ;break ; } 接下来说一种不常见的,但是对于多参数有很大的帮助的写法: 先给一 ...
- Java基础之循环语句、条件语句、switch case 语句
Java 循环结构 - for, while 及 do...while 顺序结构的程序语句只能被执行一次.如果您想要同样的操作执行多次,,就需要使用循环结构. Java中有三种主要的循环结构: whi ...
- python技巧 switch case语句
不同于C语言和SHELL,python中没有switch case语句,关于为什么没有,官方的解释是这样的 使用Python模拟实现的方法: def switch_if(fun, x, y): ...
随机推荐
- c++高效位运算函数之 __builtin_
https://www.cnblogs.com/tldr/p/11288935.html int __builtin_ffs (unsigned int x) 返回x的最后一位1的是从后向前第几位,比 ...
- C语言实现url解析小实例
一.前言 前面一口君写了一篇关于url的文章: <一文带你理解URI 和 URL 有什么区别?> 本篇在此基础上,编写一个简单的用于解析url的小例子, 最终目标是解析出URL中所有的数据 ...
- keepalived编译安装-麒麟v10Arm64
环境信息 操作系统: Kylin Linux Advanced Server V10 (Lance) 架构:Arm keepalived版本:2.3.1 编译 wget https://www.kee ...
- 并查集noi水题 (P1955 [NOI2015]程序自动分析)
现将输入排序,把merge排在前面 ,避免冗余计算 1 n=rd(); 2 FOR(i,1,n) 3 { 4 s[i].x=rd(),a[++tot]=s[i].x, 5 s[i].y=rd(),a[ ...
- Mathematica的介绍及使用方法
Mathematica 是由 Wolfram Research 公司开发的数学软件,可用于数学.物理.工程.生物等领域的计算和建模.其官方网站为 www.wolfram.com/mathematica ...
- JVM笔记六-堆区知识之对象生命周期和GC的关系
通过上一篇文章的学习,我们对JVM堆区有了初步的认识,接下来,我们继续展开讲解堆区. 对象生命周期和GC的关系. 我们已经知道了,堆区的新生区分成了三个部分:伊甸园区.幸存者0区.幸存者1区. 其中0 ...
- docker network macvlan
ref: Docker 网络模型之 macvlan 详解,图解,实验完整 网卡也能虚拟化?网卡虚拟化技术 macvlan 详解 docker和macvlan与host互通
- 探索不同引擎Innodb和Myisam的索引优化方案
数据库可能存在千万级的数据,必须将这些行数据以一定的结构组织起来做到高效的增删改查. 我们将分别探索innodb和myisam两种引擎的索引方案. 一.InnoDB的索引 1.假设表初始没有记录,只有 ...
- C++: 智能指针的自定义删除器 `Custom Deleter` 有什么用?
C++11智能指针std::shared_ptr和std::unique_ptr都支持自定义删除器,本文将介绍自定义删除器的使用场景和使用方法.智能指针模板参数的第二个类型是删除器,一般是一个函数指针 ...
- Naming Conversion & Case Style 命名规范
前言 写代码有 2 个点很重要 第一是表达 (不要词不达意) 要达到这点, 就要多参考其它人如何表达. 第二是一致性 (一样的东西就用一样的写法) 要达到这点就要建立规范 以前的笔记 命名规范 nam ...