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

Halcon抛出异常日志

Halcon 抛出异常日志

// 捕获Halcon异常并生成格式化的错误日志信息
// 参数说明:
// - HDevExpDefaultException:Halcon异常对象引用,包含具体的异常信息
// - functName:发生异常的函数名称,用于日志定位
// - htMessage:输出参数,用于存储格式化后的完整错误信息
void CatchHexceptLog(const HalconCpp::HException& HDevExpDefaultException, std::string functName, std::string& htMessage)
{// 定义变量,用于存储异常发生的行号和操作符字符串std::string strLine, strOperator;// 定义Halcon数据结构HTuple,用于存储异常相关信息// htException:存储转换后的异常数据// hv_ErrorLine:存储异常发生的程序行号// hv_Operator:存储发生异常的Halcon操作符// hv_OperatorMsg:存储操作符相关的错误消息HTuple  htException, hv_ErrorLine, hv_Operator, hv_OperatorMsg;// 将HException异常对象转换为HTuple类型,便于后续提取异常详情HDevExpDefaultException.ToHTuple(&htException);// 从异常数据中提取"program_line"(程序行号)信息,存储到hv_ErrorLineHException::GetExceptionData(htException, "program_line", &hv_ErrorLine);// 从异常数据中提取"operator"(操作符)信息,存储到hv_OperatorHException::GetExceptionData(htException, "operator", &hv_Operator);// 从异常数据中提取"error_message"(错误消息)信息,存储到hv_OperatorMsgHException::GetExceptionData(htException, "error_message", &hv_OperatorMsg);// 将行号从HTuple类型转换为std::string类型,便于字符串拼接strLine = hv_ErrorLine.ToString().Text();// 将操作符从HTuple类型转换为std::string类型strOperator = hv_Operator.ToString().Text();// 构建基础错误信息,包含行号、操作符和消息前缀std::string Message = "Line:" + strLine + ", Op:" + strOperator + ", Msg:";// 获取异常的错误消息字符串(HException自带的错误描述)std::string msgError = HDevExpDefaultException.ErrorMessage();// 组合所有信息:函数名 + 基础错误信息 + 详细错误描述,存入输出参数htMessage = functName + "-->" + Message + msgError;
}

使用方式

try{
// ...省略
}
catch (HException& excp)
{std::string errMess;CatchHexceptLog(excp, __FUNCTION__, errMess);qDebug() << str2QStr(errMess);return false;
}
http://www.hskmm.com/?act=detail&tid=13770

相关文章:

  • [PaperReading] Mind Search: Mimicking Human Minds Elicits Deep AI Searcher
  • 穷举法(c语言版)
  • ZYNQ PS 端 UART 接收数据素材帧(初学者友好版)嵌入式编程 C语言 c++ 软件开发
  • 详细介绍:深入理解Kafka事务
  • 能碳园区 / 工厂系统 - 智慧园区
  • 代码随想录算法训练营第五天 |242.有效的字母异位词、349. 两个数组的交集、第202题. 快乐数、1. 两数之和
  • Photoshop 2025 v26.0(PS2025)下载安装教程(含一键安装包下载)
  • 网络加速原理
  • 循环依赖问题
  • 无意中在应用层瞥见了一个微内核的操作系统调度器
  • 数据结构思维题选做(长期更新)
  • 政治笔记/错题
  • 9.22模拟赛总结
  • 莫队 n的序列,多次查询一段区间内的数字的个数
  • 【mysql】mysql客户端中文显示乱码
  • 揭秘“牛牛透视”
  • k8s系列--控制器yml(15)
  • 学生管理系统案例初步分析报告
  • 【mysql】mysql5.6 版本修改用户的登录
  • AT_abc200_e [ABC200E] Patisserie ABC 2 题解
  • 日总结 5
  • Linux驱动开发(1)概念、环境与代码框架 - 实践
  • Diffutoon下载介绍:真人视频转动漫工具,轻松获得上千点赞
  • 9月22号
  • 0.5*8 边形 != 式
  • 题解:AT_agc052_c [AGC052C] Nondivisible Prefix Sums
  • 寻路算法
  • 2025年9月22日 - 20243867孙堃2405
  • day 1
  • [Paper Reading] METAGPT: META PROGRAMMING FOR A MULTI-AGENT COLLABORATIVE FRAMEWORK