LabVIEW做为一个编程开发平台,和其它的文本编程环境一样,当我们编写的程序变得很大时,为了能在调试的时候快速的定位问题,也为了能在最终用户使用时,对于突发的错误或者可预知的错误能够通过一定的处理进行纠正或关闭应用程序,避免错误的进一步发生。这就需要LabVIEW开发人员在开发应用程序时,能够合理的使用一种错误处理策略。这篇文章中,我们将会给大家介绍一些LabVIEW中的基本的和高阶的错误处理技巧,提高应用程序鲁棒性。
关键字:LabVIEW 错误处理
引用地址:LabVIEW中的错误处理
默认的,LabVIEW是会进行自动错误处理的。这表现在当程序执行过程中出现错误时(如加载文件失败),程序会挂起,LabVIEW会自动弹出错误对话框,并高亮导致错误产生的子VI或函数模块。在LabVIEW中可以通过:1)工具>>选项>>程序框图>>错误处理:该分支下有两个选项可以决定是否使能自动错误处理;2)对于单个VI,文件>>VI属性>>执行:该分支下可以选择是否对当前VI关闭自动错误处理。
如果希望程序在执行过程中出现错误时能给出更有意义的提示信息,我们可以使用自定义错误处理。首先评估一下该应用中,有可能会出现哪些错误,并给这个错误赋特定的错误代码(error code)和描述信息(description)。LabVIEW预留了以下错误代码供用户自定义错误使用:-8999到-8000,5000到9999,500000到599999。比如:在一个数据采集应用中,需要监测外部信号的幅值,当幅值大于8V时,我们可以定义该错误码为6000,并通过General Error Handler函数弹出相应对话框。(参考basic error handling.vi)
图1. 通用错误处理
上述这种方式,如果程序很大时,为了不遗漏掉各部分可能产生的错误,我们需要不断的放置General Error Handler函数,并给它不断的配置“用户自定义代码”和“用户自定义描述信息”,时间长了,就难于维护,而且很难面面俱到,而且增大代码的体积和占用配图的空间。有没有一种全局的方式呢?答案是肯定的,在LabVIEW中通过:工具>>高级>>编辑错误代码,弹出错误代码编辑对话窗口,可以新建或修改现有的文件。在错误编辑窗口中可以添加自定义错误代码和相应的文本描述信息。如果是新建的文件,点击Save按钮时会弹出对话框提示保存,文件名称必须是xxx-errors.txt,xxx是用户可以自由命名部分。xxx-errors.txt文件的存放目录必须在:盘符:\Program Files\National Instruments\LabVIEW 2011\user.lib\errors目录下(这里以LabVIEW 2011为例,其中盘符为LabVIEW所在的安装目录),如果没有errors目录,可以手动创建。xxx-errors.txt文件在LabVIEW关闭并重启后才生效。
图2. 错误代码编辑对话窗口
到这里的时候,如果只是一个人在孤独的写程序,那么通过xxx-errors.txt文件对自定义错误代码进行管理就基本上能满足一个LabVIEW开发者在同一台计算机上的要求了。但是在很多情况下,我们开发的应用程序最终可能会在其它计算机上部署或运行,或者要共享给其他开发人员,那怎么使得xxx-errors.txt得以复用。
如果是把源代码共享给另一个开发人员,只需要从原来的计算机上将xxx-errors.txt文档拷贝到对方计算机上的相应目录:盘符:\Program Files\National Instruments\LabVIEW 2011\user.lib\errors下即可。如果是生成Executable文件,那么在Executable的属性配置窗口的高级页面中,勾选上“拷贝错误代码文件”,这样在生成Executable时,会自动将”盘符:\Program Files\National Instruments\LabVIEW 2011\user.lib\errors”下所有的xxx-errors.txt复制到”C:\Program Files\National Instruments\Shared\LabVIEW Run-Time\2011\errors”目录下(这里以LabVIEW 2011为例,该路径为LabVIEW Run-Time的目录)。
图3. Executable的属性配置窗口
但这只是在原来的计算机上做了一次复制,要在目标计算机上运行,除了拷贝Executable文件,必须将xxx-errors.txt文件手动拷贝到目标计算机的LabVIEW Run-time目录下。大家可能会有疑问,要是这样的话,那图3中的勾选项还有什么用!确实,如果只是在目标机上运行Executable,是否勾选上都无所谓。但是当我们勾选上之后,进一步生成安装文件时,在安装文件的属性配置窗口的附加安装页面中,勾选上LabVIEW Run-time Engine,这样安装文件中将会包含LabVIEW Run-time Engine,而xxx-errors.txt在之前生成Executable时已经拷贝到LabVIEW Run-time Engine目录下了,也将包含在Installer中,所以在目标计算机上安装Installer时,就不再需要手动拷贝xxx-errors.txt文件了。
好了,到这里为止。基础知识我们介绍完了,接下来我们介绍对于可预见的错误,是否可以选择直接忽略,或者前几次尝试忽略直到该特定错误出现很多次后才通知用户需要纠正该错误了;是否可以对重要的错误进行存档;当主VI中多个线程时,如果某一个线程出错,如何保证其它线程进行适当的收尾后同样优雅的退出,避免一错再错。这里我编写了一个参考VI,我们将详细介绍:
图4.项目文件概览
打开Error Handling in LabVIEW.vi的程序框图,其包含三个循环,分别是Producer loop,Consumer loop,Display Loop。Producer loop用于响应用户事件,并通过队列通知Consumer loop执行相应的操作;Display loop用于对前面板显示控件进行更新。
图5.项目原理图
Error Handling in LabVIEW.vi中关于错误处理部分最核心的VI是Error Module.vi。它其实是一个功能全局变量,包含Initialize,Handle Errors和Report Errors三个分支。Initialize分支中定义好哪些错误代码是直接被忽略的,哪些错误代码是允许出现若干次,并且为了实现在主VI Error Handling in LabVIEW.vi的任何一个循环出现错误时,所有的其它循环也能够退出,在Initialize分支中将分别获取三个循环中的相应队列引用或用户事件引用。
图6.Error Module模块
图7. Initialize分支
先介绍一下Error Handling Info簇控件,它包含两个数组。数组Ignore中定义的Error Code即我们希望Error Module.vi直接忽略的;Retry是簇数组,每个簇中包含三个元素:Code即我们希望出错后重试的代码,Retry times为允许出错的次数,Current Iteration记录了该特定错误已经发生的次数(在主VI中不要设置,让它为0)。我们希望当Current Iteration < Retry times时,如果该错误出现,我们可以忽略该错误,但是Current Iteration值加1。对于本次测试,主VI给Error Module.vi的传递的参数如下,我们将在后面看到,5556的错误将被直接忽略,而5557的错误第三次出现时程序将弹出对话框提示出错。
图8. Error Handling Info簇控件信息
Error Module.vi中最重要的是Handle Errors分支,简单的说,它其实是包含两层条件结构嵌套,三种处理情况。1)错误直接被忽略;2)错误符号Retry的条件;3)错误不能被预处理,将错误存档。
图9. Handle Errors分支
当错误不能被预处理时,将错误存档后,我们调用General Error Handler函数,这样就会弹出错误对话框,对话框中包含xxx-errors.txt文件中定义好的描述信息。除了将错误存档,在程序中同时通过元素入队列、产生用户事件使得主VI中的Consumer loop,Display loop和Producer loop都能够优雅的退出。
接下来我们来看一下程序的测试:
图10.主VI前面板
1. 点击Acquire按钮,将获取波形;
2. 点击Generate error for consumer,将使得Consumer loop产生error 5555,由于5555不包含在预处理的情况中,Error Module.vi的Handle Errors分支将该错误存档并弹出错误对话框,同时其它循环通过元素入队列,产生用户事件而退出,整个程序停止运行;
3. 重新运行程序,点击Generate error for Ignore按钮,可以看到,程序将继续正常运行,完全忽略该错误;
4. 点击Generate error for Retry按钮,当点击第三次时,才弹出错误对话框,程序停止运行。如下图所示:
图11. 错误代码5557重复出现3次
上一篇:运用NI USRP打造出经济实惠的8x8 MIMO测试台
下一篇:在您的PLC中添加LabVIEW的十大理由
推荐阅读最新更新时间:2024-03-30 23:19
LabVIEW程序的调试方式
调试工具是任何一种程序开发环境都必须提供的功能,它们可以显著地提高程序员的开发效率。LabVIEW作为一种图形化程序设计语言的IDE工具(同时也是一门独特的语言),自然需要考虑为工程师提供适合于图形化语言调试的工具。 事实上,LabVIEW并没有规定哪些工具被划分为调试工具,哪些工具被划分为其它的工具。这种界限和定义是比较模糊的,在实际使用中,我们可以把辅助程序员更准确、快捷地定位代码执行和Bug的工具统称为 调试工具 。 LabVIEW主要的调试工具位于工具栏,如图 1所示。从左至右依次是: Run:运行,单击它会直接运行当前的VI,快捷键Ctrl + R。 Run Continuously:连续运行。 Abort Exe
[测试测量]
LabVIEW自动连线功能
将选中的对象移到程序框图上其他对象旁边时,LabVIEW会自动提示有效的连线方式;将对象拖动放置在程序框图上时,放开鼠标后将自动连线。自动连线功能只为数据类型相互匹配的接线端连线,对不匹配的接线端不予连线。 将两个不同类型的数值数据连接在一起时,程序框图节点上会出现强制转换点提示。强制转换点表示,LabVIEW已经将传递给节点的数值强制转换成了不同的数据类型。例如,加函数节点需要两个双精度浮点数输入,如果其中一个输入为整数,在加函数节点上就会显示一个强制转换点,如图1所示。 当试图连接数据类型不兼容的两个对象或删除连线的一段时,会出现断线。断线在程序框图中显示为黑色的虚线,线段中间有个红色的X,X两边的箭头表明了数据流
[测试测量]
基于labview的工控机与变频器间通讯的设计和实现
1 引言 风力发电机组中的齿轮箱是一个重要的机械部件,而其中轴承性能的好坏对齿轮箱的性能起着至关重要的作用。根据用户要求,齿轮箱轴承出厂前要在模拟实际工况的试验机上进行测试。即齿轮箱轴承需在不同转速、载荷下进行性能试验和寿命试验。齿轮箱轴承转速的改变是由变频器驱动变频电机实现的。变频器运行频率的设定有三种方法:一是通过面板手工调节,这种方式已经不能满足频率频繁变化时使用需要。二是通过变频器的外部接口,外接模拟信号来控制设定频率。这种方式虽然简单,但存在设定频率不准确的问题,当外接模拟信号波动时,变频器的设定频率也随之变化。三是通过变频器的通讯口,利用参数设定指令来进行频率参数设定。这种方法能准确地控制变频器的频率。下面以台达
[模拟电子]
LabVIEW的PXI总线规范的结构
PXI总线规范涵盖了三大方面的内容,包括机械规范、电气规范和软件规范。PXI总线规范结构如图1所示。
如图1 PXI总线规范结构
在机械规范方面,PXI应用了与CompactPCI相同的用于远距离通信等高性能领域的针孔连接器,这种由IEC-1076标准定义的高密度阻抗匹配连接器可以在各种条件下提供良好的电气性能;PXI的机械封装和CompactPCI一样采用了ANSI-310-C、IEC-297和IEEE-1101.1等在工业环境下具有很长应用历史的Eurocard规范。
与CopactPCI不同的是,CompactPCI系统槽可位于背板总线的任何地方,而PXI规定系统槽位于总线的最左端。
[嵌入式]
波音公司使用NI的PXI硬件和LabVIEW平台
The Challenge: 创建一个可升级的高性价比系统来测试新设计的有效性,该设计被用于减少商业喷气式客机在起飞、降落和持续飞行过程中发出的噪音。 The Solution: 使用NI 的PXI 控制器、机箱、动态信号分析仪和LabVIEW 软件来设计一个可升级的分布式测试系统,该系统拥有严格的定时和同步功能,用于在飞机低空飞行测试时进行相控阵数据采集。 "利用NI的软硬件平台,我们可以创建一个高性价比的高端系统,把采集系统分布地放置在多个机箱中,严格同步所有的通道。" 相控阵低空飞行测试 我们用600多个基地麦克风来装备我们的测试系统,这些麦克风被按照自定义的螺旋状方式安装在一个250 英尺宽、300 英尺长
[测试测量]
基于Labview的蓄电池在线监测系统设计
由于交流市电在供应的过程中可能会出现停电、电压下陷上涌、持续欠压过压以及频率波动等不确定的干扰因素,这些因素会对网络的持续运行造成影响,甚至对处于运行状态的网络设备和服务器造成损坏。各个企业在构建网络系统的时候,在计算机网络供电方面都会采取必要的措施以提供高质量的UPS电源。这其中蓄电池组作为动力供应的最后保障,无疑是电源中的最后保险。而蓄电池的工作状态将直接影响UPS系统的稳定性,所以必须对电池组的工作状态进行实时监测。可见,对电源中蓄电池的准确监测变得非常重要。为了实现对蓄电池各参数的准确检测,在做了需求分析的基础上,提出并设计了一种基于Labview的蓄电池在线监测系统(以下简称“监测系统”)设计方案。该系统能够完成对
[电源管理]
基于LabVIEW的继电器测试系统的设计方案
1.引言 继电器是自动控制系统、遥控遥测系统和通信系统的关键元件之一,它广泛应用于航空、航天、 电子 、通信、机械等装备中,继电器的可靠性直接影响到由其组成的设备、系统的可靠性,继电器的测试是保证其可靠性的重要技术。 目前国内的继电器测试系统有很多,但大部不够完善。手动方式的测试系统,操作复杂,易受主观因素影响,测试结果误差较大: 其余方式的测试系统,功能单一、灵活性差,开发周期长,维护困难。这些测试系统对超小电流进行准确测量比较困难,而且无法一次准确测量继电器的多组 触点 状态,继电器错判率高,不够可靠。 本系统采用NI发布的Lab-VIEW8.5软件,通过对研华功能板卡的控制,实现对继电器进行自动测试和
[测试测量]
我对虚拟仪器技术的理解
从事虚拟仪器技术已经有好多年了,虽然这两年从事其他方面的工作,但还一直在关注该领域的变化。从上研究生开始就一直从事虚拟仪器方面的工作,我本人主要做硬件方面的事情,但是一直在考虑虚拟仪器方面的几个重要问题:什么是虚拟仪器技术?虚拟仪器技术研究内容是什么?在此,我想谈谈我对上述问题的一些想法。 首先,什么是虚拟仪器技术?提到这个问题很多朋友可能脱口而出:“虚拟仪器是不是一种模拟仿真的仪器?”,“虚拟仪器技术就是用Labview进行测试测量的开发”,“虚拟仪器技术就是基于计算机的测控系统”。从google中搜索“虚拟仪器”关键字,可能得到最多的是NI公司的咨讯,然后是铺天盖地的Labview信息,再者就是NI推出的各种模块化
[测试测量]