LabVIEW中的錯誤處理
默認的,LabVIEW是會進行自動錯誤處理的。這表現(xiàn)在當程序執(zhí)行過程中出現(xiàn)錯誤時(如加載文件失敗),程序會掛起,LabVIEW會自動彈出錯誤對話框,并高亮導致錯誤產(chǎn)生的子VI或函數(shù)模塊。在LabVIEW中可以通過:1)工具>>選項>>程序框圖>>錯誤處理:該分支下有兩個選項可以決定是否使能自動錯誤處理;2)對于單個VI,文件>>VI屬性>>執(zhí)行:該分支下可以選擇是否對當前VI關閉自動錯誤處理。
如果希望程序在執(zhí)行過程中出現(xiàn)錯誤時能給出更有意義的提示信息,我們可以使用自定義錯誤處理。首先評估一下該應用中,有可能會出現(xiàn)哪些錯誤,并給這個錯誤賦特定的錯誤代碼(error code)和描述信息(description)。LabVIEW預留了以下錯誤代碼供用戶自定義錯誤使用:-8999到-8000,5000到9999,500000到599999。比如:在一個數(shù)據(jù)采集應用中,需要監(jiān)測外部信號的幅值,當幅值大于8V時,我們可以定義該錯誤碼為6000,并通過General Error Handler函數(shù)彈出相應對話框。(參考basic error handling.vi)
圖1.通用錯誤處理
上述這種方式,如果程序很大時,為了不遺漏掉各部分可能產(chǎn)生的錯誤,我們需要不斷的放置General Error Handler函數(shù),并給它不斷的配置“用戶自定義代碼”和“用戶自定義描述信息”,時間長了,就難于維護,而且很難面面俱到,而且增大代碼的體積和占用配圖的空間。有沒有一種全局的方式呢?答案是肯定的,在LabVIEW中通過:工具>>高級>>編輯錯誤代碼,彈出錯誤代碼編輯對話窗口,可以新建或修改現(xiàn)有的文件。在錯誤編輯窗口中可以添加自定義錯誤代碼和相應的文本描述信息。如果是新建的文件,點擊Save按鈕時會彈出對話框提示保存,文件名稱必須是xxx-errors.txt,xxx是用戶可以自由命名部分。xxx-errors.txt文件的存放目錄必須在:盤符:Program FilesNational InstrumentsLabVIEW 2011user.liberrors目錄下(這里以LabVIEW 2011為例,其中盤符為LabVIEW所在的安裝目錄),如果沒有errors目錄,可以手動創(chuàng)建。xxx-errors.txt文件在LabVIEW關閉并重啟后才生效。
圖2. 錯誤代碼編輯對話窗口
到這里的時候,如果只是一個人在孤獨的寫程序,那么通過xxx-errors.txt文件對自定義錯誤代碼進行管理就基本上能滿足一個LabVIEW開發(fā)者在同一臺計算機上的要求了。但是在很多情況下,我們開發(fā)的應用程序最終可能會在其它計算機上部署或運行,或者要共享給其他開發(fā)人員,那怎么使得xxx-errors.txt得以復用。
如果是把源代碼共享給另一個開發(fā)人員,只需要從原來的計算機上將xxx-errors.txt文檔拷貝到對方計算機上的相應目錄:盤符:Program FilesNational InstrumentsLabVIEW 2011user.liberrors下即可。如果是生成Executable文件,那么在Executable的屬性配置窗口的高級頁面中,勾選上“拷貝錯誤代碼文件”,這樣在生成Executable時,會自動將”盤符:Program FilesNational InstrumentsLabVIEW 2011user.liberrors”下所有的xxx-errors.txt復制到”C:Program FilesNational InstrumentsSharedLabVIEW Run-Time2011errors”目錄下(這里以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時已經(jīng)拷貝到LabVIEW Run-time Engine目錄下了,也將包含在Installer中,所以在目標計算機上安裝Installer時,就不再需要手動拷貝xxx-errors.txt文件了。
好了,到這里為止?;A知識我們介紹完了,接下來我們介紹對于可預見的錯誤,是否可以選擇直接忽略,或者前幾次嘗試忽略直到該特定錯誤出現(xiàn)很多次后才通知用戶需要糾正該錯誤了;是否可以對重要的錯誤進行存檔;當主VI中多個線程時,如果某一個線程出錯,如何保證其它線程進行適當?shù)氖瘴埠笸瑯觾?yōu)雅的退出,避免一錯再錯。這里我編寫了一個參考VI,我們將詳細介紹:
圖4.項目文件概覽
打開Error Handling in LabVIEW.vi的程序框圖,其包含三個循環(huán),分別是Producer loop,Consumer loop,Display Loop。Producer loop用于響應用戶事件,并通過隊列通知Consumer loop執(zhí)行相應的操作;Display loop用于對前面板顯示控件進行更新。
圖5.項目原理圖
Error Handling in LabVIEW.vi中關于錯誤處理部分最核心的VI是Error Module.vi。它其實是一個功能全局變量,包含Initialize,Handle Errors和Report Errors三個分支。Initialize分支中定義好哪些錯誤代碼是直接被忽略的,哪些錯誤代碼是允許出現(xiàn)若干次,并且為了實現(xiàn)在主VI Error Handling in LabVIEW.vi的任何一個循環(huán)出現(xiàn)錯誤時,所有的其它循環(huán)也能夠退出,在Initialize分支中將分別獲取三個循環(huán)中的相應隊列引用或用戶事件引用。
圖6.Error Module模塊
圖7. Initialize分支
先介紹一下Error Handling Info簇控件,它包含兩個數(shù)組。數(shù)組Ignore中定義的Error Code即我們希望Error Module.vi直接忽略的;Retry是簇數(shù)組,每個簇中包含三個元素:Code即我們希望出錯后重試的代碼,Retry times為允許出錯的次數(shù),Current Iteration記錄了該特定錯誤已經(jīng)發(fā)生的次數(shù)(在主VI中不要設置,讓它為0)。我們希望當Current Iteration < Retry times時,如果該錯誤出現(xiàn),我們可以忽略該錯誤,但是Current Iteration值加1。對于本次測試,主VI給Error Module.vi的傳遞的參數(shù)如下,我們將在后面看到,5556的錯誤將被直接忽略,而5557的錯誤第三次出現(xiàn)時程序?qū)棾鰧υ捒蛱崾境鲥e。
圖8. Error Handling Info簇控件信息
Error Module.vi中最重要的是Handle Errors分支,簡單的說,它其實是包含兩層條件結(jié)構(gòu)嵌套,三種處理情況。1)錯誤直接被忽略;2)錯誤符號Retry的條件;3)錯誤不能被預處理,將錯誤存檔。
圖9. Handle Errors分支
當錯誤不能被預處理時,將錯誤存檔后,我們調(diào)用General Error Handler函數(shù),這樣就會彈出錯誤對話框,對話框中包含xxx-errors.txt文件中定義好的描述信息。除了將錯誤存檔,在程序中同時通過元素入隊列、產(chǎn)生用戶事件使得主VI中的Consumer loop,Display loop和Producer loop都能夠優(yōu)雅的退出。
接下來我們來看一下程序的測試:
圖10.主VI前面板
1.點擊Acquire按鈕,將獲取波形;
2.點擊Generate error for consumer,將使得Consumer loop產(chǎn)生error 5555,由于5555不包含在預處理的情況中,Error Module.vi的Handle Errors分支將該錯誤存檔并彈出錯誤對話框,同時其它循環(huán)通過元素入隊列,產(chǎn)生用戶事件而退出,整個程序停止運行;
3.重新運行程序,點擊Generate error for Ignore按鈕,可以看到,程序?qū)⒗^續(xù)正常運行,完全忽略該錯誤;
4.點擊Generate error for Retry按鈕,當點擊第三次時,才彈出錯誤對話框,程序停止運行。如下圖所示:
圖11. 錯誤代碼5557重復出現(xiàn)3次
評論