halcon/c++接口基础 之异常处理

关于运行错误,HALCON/C++默认打印错误信息并且终止程序。然而在某些应用中,放宽这个法则可能更有用。比如,如果一个应用要求用户交互式地指定一个图像文件读取,如果因为用户不能拼错文件名而终止程序的话,会很不方便。因此,HALCON/C++允许集成你自己的错误处理代码。如下的章节将分别介绍面向对象的方法和面向过程的方法

面向对象的方法

如果一个运行错误发生在面向对象的调用中,类HException的实例将会创建。(图5.8为类的定义)

class LIntExport HException {
public:
  HException(const HException &except);
  HException(const char *f, Hlong l, const char *p, Herror e, const char *m);
  HException(const char *f, Hlong l, const char *p, const char *m);
  HException(const char *f, Hlong l, const char *p, Herror e);

  static Handler InstallHHandler(Handler proc);
  void           PrintException(void);

  static Handler handler;   /* handler in use */
  Hlong          line;      /* line number where error occured */
  char           *file;     /* file name where error occured */
  char           *proc;     /* Name of procedure/operator */
  Herror         err;       /* error number */
  char           *message;  /* error text */
};

Figure 5.8: Part of the declaration of the class HException.
以上这个例子,包含了错误的所有信息。其中一个异常重要的成员如下:

  • line:错误发生的项目行号
  • file:错误发生的文件名
  • proc:实际的HALCON算子的名字
  • err: 错误代号,see below
  • message: 错误文本
    当发生后,HException的对象被传递到所谓的异常句柄。HALCON的默认异常句柄将打印对应的错误信息,并且终止程序。

作为另一种可替代的方法,你可以实现和使用你自己的异常处理。为了作为HALCON exception handler,一个程序必须有如下的签名:

typedef void (*Handler)(const Halcon::HException &exception);

然后通过HException的方法InstallHHandler安装你的异常处理程序。(见图5.8)这样一旦发生了运行错误,HALCON然后调用你自己的程序,传递实际的异常的对象作为参数。

如下的例子将展示如何使用一个用户指定的异常处理器和标准的C++异常处理机制(try catch)一起使用.对应的项目example_errorhandle.cpp可以在%HALCONEXAMPLES%\cpp的子目录找到。它实现了以上指定的目的:你可以键入一个文件名去读取;如果文件不存在,项目将打印一个对应的信息但不会停止程序,而是继续运行。

项目的开始,一个用户指定的异常处理器使用如下的方法安装:

HException::InstallHHandler(&MyHalconExceptionHandler);

被安装的程序简单地调用C++的异常处理机制throw:

void MyHalconExceptionHandler(const Halcon::HException& except)
{
  throw except; 
}

ReadImage的调用被一个try 区域封装,一个可能的异常可以在catch中捕获:

Herror  error_num; 

try
{
  image = HImage::ReadImage(filename); 
}
catch (HException &except) 
{
  error_num = except.err;
  return error_num;
}
return H_MSG_TRUE;

面向过程的方法

正如section “Calling HALCON Operators”中看到的那样,面向过程的方法返回一个Herror类型的数据。这个数据会分为两类:信息H_MSG_* and 错误 H_ESR_*.

典型地,如果没有错误发生,HALCON算子返回信息H_MSG_TRUE.

一旦遇到一个错误,HALCON默认打印所谓的错误信息并且终止程序。你可以通过算子set_check指定异常是否忽略。如下的例子代码检测一个文件是否正确打开;一旦遇到错误,将打印所谓的错误信息,可以通过get_error_text获得错误信息。

Herror         error_num;
char           message[1024];
long           file;

set_check("~give_error");
error_num = open_file("not_existing_file", "input", &file); 
set_check("give_error");

if (error_num != H_MSG_TRUE) 
{
  get_error_text(error_num, message);
  cout << "HALCON error " << error_num << ": " << message;
}

请注意一些数组算子没有返回值。这样,被描述的方法会导致一个内存泄漏。请使用面向对象的方法代替。


打赏

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值