• 现象

今天遇到了一个神奇的BUG,主程序调用了一个包含类的打包库,打包库中将字符串还原为类句柄时报错。

调用程序结构如下:.

Labview 错误1400-打包库封装类时将对类重命名导致-LMLPHP

主程序中将类句柄转化为XML字符串程序如下:

Labview 错误1400-打包库封装类时将对类重命名导致-LMLPHP

打包库内将字符串还原为句柄程序如下:

Labview 错误1400-打包库封装类时将对类重命名导致-LMLPHP

错误弹窗如下:

Labview 错误1400-打包库封装类时将对类重命名导致-LMLPHP

在开发环境下运行VCI_CAN.vi可正常还原字符串,仅以打包库的形式调用时报错

  • 溯源

在NI查到如下内容:

Labview 错误1400-打包库封装类时将对类重命名导致-LMLPHP

参考链接https://knowledge.ni.com/KnowledgeArticleDetails?id=kA00Z000000kHquSAE&l=zh-CN

怀疑Labview在生成打包库时也会对类的名词进行更改,修改打包库内的程序

将打包库内的类句柄平化为XML字符串并与主程序内的字符串一起弹窗显示:

Labview 错误1400-打包库封装类时将对类重命名导致-LMLPHP

弹窗如下;

Labview 错误1400-打包库封装类时将对类重命名导致-LMLPHP

上面的是主程序里的Class名称和版本,下边是打包库里的Class名称和版本

  • 解决方案

确认打包库在对类封装时会对其重命名,无法通过平化还原字符串向打包库内传递类句柄。

考虑到Class的句柄的格式是固定,可在主程序内直接格式化字符串,在打包库内扫描字符串还原为句柄。

在类里增加方法ClassToString和StringToClass

Labview 错误1400-打包库封装类时将对类重命名导致-LMLPHP

Labview 错误1400-打包库封装类时将对类重命名导致-LMLPHP

主程序内程序更新如下:

Labview 错误1400-打包库封装类时将对类重命名导致-LMLPHP

打包库内更新如下:

Labview 错误1400-打包库封装类时将对类重命名导致-LMLPHP

验证,问题解决。

05-15 16:43