上位机调试记录之Debug Assertion Failed!

2024-01-14 20:38

本文主要是介绍上位机调试记录之Debug Assertion Failed!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. Bug现象还原

使用Debug模式调试USB上位机时,出现了下方错误提示,使用Release模式却不会出现!

2.问题定位

将下方代码进行屏蔽后,错误提示消失

Display_data_512x8bit(data);

data_receive_512x8bit +=_T("USB接收端点无数据输出!\r\n");

UpdateData(false);

可以猜测变量data_receive_512x8bit是引起报错的原因

void CUSBprojDlg:: Creat_file(UCHAR * data,bool success)
{CString str;LONG nLen=512;CTime t=CTime::GetCurrentTime();if(success){str=t.Format(_T("D:\\USB_file_recevie\\file_%Y%m%d%H%M%S.hex")); mFile.Open(str,CFile::modeWrite|CFile::modeCreate);         //打开文件mFile.SetLength(0);                                          //清空文件mFile.SeekToEnd();mFile.Write(data,nLen);	mFile.Flush();//强制将缓冲区数据写入磁盘文件						mFile.Close();//关闭文件//Display_data_512x8bit(data);str=t.Format(_T("Saved to file_%Y%m%d%H%M%S.hex"));SetDlgItemText(IDC_DATAIN,str);	 }else{//data_receive_512x8bit +=_T("USB接收端点无数据输出!\r\n");SetDlgItemText(IDC_DATAIN,_T("请先向FPGA发送数据!"));//UpdateData(false);}
}

data_receive_512x8bit为一CString全局Public变量,用于显示接收的512字节数据,与之相关的代码如下,在界面显示时使用UpdateData(false)来刷新。

CString data_receive_512x8bit;DDX_Text(pDX, IDC_data_receive_display, data_receive_512x8bit);data_receive_512x8bit +=_T("USB接收端点无数据输出!\r\n");
SetDlgItemText(IDC_DATAIN,_T("请先向FPGA发送数据!"));
UpdateData(false);
void CUSBprojDlg::Display_data_512x8bit(UCHAR * data_512)
{int i=0;int j=0;int line=1;CString str=_T("512x8bit data receive from USB: \r\nline00:  ");CString tmp_str=_T("");for(i=0;i<512;i++){tmp_str.Format(_T("%02X"),data_512[i]);tmp_str+=_T(" ");str+=tmp_str;if((j!=0)&&(j!=511)&&((j+1)%16==0)) {str+=_T(" \r\n");tmp_str.Format(_T("line%02d:  "),line);str+=tmp_str;line++;}j++;}data_receive_512x8bit =str;data_receive_512x8bit +=_T(" \r\n \r\n");UpdateData(false);
}

3. 解决思路

去掉全局变量data_receive_512x8bit,直接使用函数SetDlgItemTextW()对文本控件IDC_data_receive_display进行操作,

代码修改方法如下:

SetDlgItemTextW(IDC_data_receive_display,data_receive_512x8bit);
void CUSBprojDlg::Display_data_512x8bit(UCHAR * data_512)
{int i=0;int j=0;int line=1;CTime t=CTime::GetCurrentTime();CString str=_T("512x8bit data receive from USB: \r\nline00:  ");CString tmp_str=_T("");for(i=0;i<512;i++){tmp_str.Format(_T("%02X "),data_512[i]);	str+=tmp_str;if((j!=0)&&(j!=511)&&((j+1)%16==0)) {str+=_T(" \r\n");tmp_str.Format(_T("line%02d:  "),line);str+=tmp_str;line++;}j++;}data_receive_512x8bit =str;data_receive_512x8bit +=_T(" \r\n \r\n");data_receive_512x8bit +=t.Format(_T("Saved to D:\\USB_file_recevie\\file_%Y%m%d%H%M%S.hex!\r\n"));SetDlgItemTextW(IDC_data_receive_display,data_receive_512x8bit);  
}

4. 参考:

[1] File: f:\dd\vctools\vc7libs\ship\atlmfc\src\mfc\winocc.cpp的子窗口初始化问题 - xiaoshengforever的专栏 - CSDN博客
https://blog.csdn.net/xiaoshengforever/article/details/11882027

这篇关于上位机调试记录之Debug Assertion Failed!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/606441

相关文章

Goland debug失效详细解决步骤(合集)

《Golanddebug失效详细解决步骤(合集)》今天用Goland开发时,打断点,以debug方式运行,发现程序并没有断住,程序跳过了断点,直接运行结束,网上搜寻了大量文章,最后得以解决,特此在这... 目录Bug:Goland debug失效详细解决步骤【合集】情况一:Go或Goland架构不对情况二:

关于Spring @Bean 相同加载顺序不同结果不同的问题记录

《关于Spring@Bean相同加载顺序不同结果不同的问题记录》本文主要探讨了在Spring5.1.3.RELEASE版本下,当有两个全注解类定义相同类型的Bean时,由于加载顺序不同,最终生成的... 目录问题说明测试输出1测试输出2@Bean注解的BeanDefiChina编程nition加入时机总结问题说明

使用C/C++调用libcurl调试消息的方式

《使用C/C++调用libcurl调试消息的方式》在使用C/C++调用libcurl进行HTTP请求时,有时我们需要查看请求的/应答消息的内容(包括请求头和请求体)以方便调试,libcurl提供了多种... 目录1. libcurl 调试工具简介2. 输出请求消息使用 CURLOPT_VERBOSE使用 C

将sqlserver数据迁移到mysql的详细步骤记录

《将sqlserver数据迁移到mysql的详细步骤记录》:本文主要介绍将SQLServer数据迁移到MySQL的步骤,包括导出数据、转换数据格式和导入数据,通过示例和工具说明,帮助大家顺利完成... 目录前言一、导出SQL Server 数据二、转换数据格式为mysql兼容格式三、导入数据到MySQL数据

关于rpc长连接与短连接的思考记录

《关于rpc长连接与短连接的思考记录》文章总结了RPC项目中长连接和短连接的处理方式,包括RPC和HTTP的长连接与短连接的区别、TCP的保活机制、客户端与服务器的连接模式及其利弊分析,文章强调了在实... 目录rpc项目中的长连接与短连接的思考什么是rpc项目中的长连接和短连接与tcp和http的长连接短

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI

Python MySQL如何通过Binlog获取变更记录恢复数据

《PythonMySQL如何通过Binlog获取变更记录恢复数据》本文介绍了如何使用Python和pymysqlreplication库通过MySQL的二进制日志(Binlog)获取数据库的变更记录... 目录python mysql通过Binlog获取变更记录恢复数据1.安装pymysqlreplicat

C++中实现调试日志输出

《C++中实现调试日志输出》在C++编程中,调试日志对于定位问题和优化代码至关重要,本文将介绍几种常用的调试日志输出方法,并教你如何在日志中添加时间戳,希望对大家有所帮助... 目录1. 使用 #ifdef _DEBUG 宏2. 加入时间戳:精确到毫秒3.Windows 和 MFC 中的调试日志方法MFC

Servlet中配置和使用过滤器的步骤记录

《Servlet中配置和使用过滤器的步骤记录》:本文主要介绍在Servlet中配置和使用过滤器的方法,包括创建过滤器类、配置过滤器以及在Web应用中使用过滤器等步骤,文中通过代码介绍的非常详细,需... 目录创建过滤器类配置过滤器使用过滤器总结在Servlet中配置和使用过滤器主要包括创建过滤器类、配置过滤

正则表达式高级应用与性能优化记录

《正则表达式高级应用与性能优化记录》本文介绍了正则表达式的高级应用和性能优化技巧,包括文本拆分、合并、XML/HTML解析、数据分析、以及性能优化方法,通过这些技巧,可以更高效地利用正则表达式进行复杂... 目录第6章:正则表达式的高级应用6.1 模式匹配与文本处理6.1.1 文本拆分6.1.2 文本合并6