成為LabVIEW漏洞修複高手
如果您經常使用NI LabVIEW軟件,當軟件不能按照預期的情況運行時,您可能會有一個自己的調試技巧和技術工具箱。 這些技巧和技術有些是常用的,而剩下的可能是您自己摸索出來的。
圖1. 巧妙的調試方法能夠清除漏洞。 (Brian Searle攝)
我們與JKI的LabVIEW程序架構師 ( Certified LabVIEW Architects, CLA ) 以及LabVIEW社區的朋友進行了交流,向他們學習一些快速識別、隔離和修複漏洞的“絕密”技巧。我們了解到以下幾個巧妙的調試技巧。
利用探針
探針是LabVIEW調試的第一個也是最簡單的工具,但它們卻是非常強大的工具。您可極其輕鬆地將探針置於線路上,在查找問題過程中不斷獲取信息。 以下是探針的幾個功能:
保存連線值功能
LabVIEW開發環境中的保存連線值功能經常會被忽略。 當您啟用某個VI的連線值保存功能時,LabVIEW將自動存儲該VI框圖上每根連線的最後一個值。 然後,將光標懸停在任一連線上,即使該VI未運行,探針工具也將出現提示信,顯示該連線最後一個值。
圖2. 保存連線值按鈕就在“燈泡”圖標旁邊。
自定義探針,無需編寫任何代碼
運用LabVIEW自定義探針,您無需編寫任何代碼就可創建強大、複雜的調試工具。 例如,您可在“自定義探針”>>“控件”>> “波形圖”中創建顯示任意數字連線的先前值的“曆史探針”。 這可幫助您發現您正在探究的數據的模式或趨勢,而無需編寫特殊的探針代碼。
圖3. 使用波形圖探針顯示簡單數字連線的曆史值。
從LabVIEW工具網絡獲取自定義探針
借用他人創建的探針來擴展您的工具箱。 SAPHIR在LabVIEW工具網絡上提供了一係列免費的自定義LabVIEW探針。 您隻需下載安裝VI軟件包管理器 (VIPM)社區版(也是免費的)、搜索ViBox,再通過幾次單擊就可安裝探針。
如果您正在使用LabVIEW 2011,您還可通過單擊LabVIEW入門指南窗口的“查找LabVIEW附加工具...”從LabVIEW工具網絡上獲取ViBox。
圖4. 使用VIPM安裝SAPHIR自定義探針。
調用時掛起
許多LabVIEW程序架構師甚至不知道LabVIEW具備該項功能。“調用時掛起”功能可將執行掛起,使您可以進行以下任一或所有操作:
在VI運行之前隨意更改VI的控件值。
VI返回調用程序時隨意更改顯示件的值。
重複運行VI,而無需將執行返回至調用程序。
完全跳過VI執行,返回至調用VI。
圖 5. 在子VI節點設置窗口中,選擇“調用時掛起”功能。
對於調用時掛起功能,NI做了簡要說明,見 此處 。 然而,熟悉該功能的最佳方法還是親自動手實踐。
未連線的前麵板控件和顯示件
為FIRST (崇尚發揚科學技術)機器人競賽團隊推薦了一項技術,這項技術對於專業的LabVIEW開發人員也非常有用
Ben建議在VI中添加前麵板控件或顯示控件,但並不 與連線板連接。 這些控件和顯示件與“調試”輸入或輸出工作方式類似,您可在測試時對其進行手動控製。 這可使您更容易在應用中生成偶然或極端事件,而無需繁多的支持或仿真代碼的寫入。
您還可以在已建應用程序中使用這些調試控件和顯示件,前提是LabVIEW應用程序生成器包含了VI前麵板。
執行跟蹤
如果其他方法都失敗的情況下,有時您所能做的隻有逐步跟蹤代碼。 遇到此類問題時,您可通過幾種方法在LabVIEW內進行執行跟蹤。
最明顯的方法是使用LabVIEW中內置的“高亮顯示執行”功能,也稱為“燈泡”。 如果說探針是LabVIEW調試的首要工具,燈泡則位列第二。 但是,如果碰到複雜或是時間相關的漏洞,您則可選擇其他更有效的工具。
圖6. 執行跟蹤功能比燈泡功能更多。
跟蹤磁盤或內存
啟動執行跟蹤的一個簡單方法是在其中一個子VI中記錄一個連線值。 您可編寫一個簡單的VI,將該值記錄到文件中,或甚至可創建一個自定義探針來顯示連線的曆史值。 通常通過這樣一個簡單的跟蹤您就可收集足夠的信息來幫助您找到漏洞的原因。
NI LabVIEW桌麵執行跟蹤工具包
如果要調試一個大型的高度並行應用程序,則包含NI開發者套件 2011的LabVIEW桌麵執行跟蹤工具包就是您進行LabVIEW代碼分析的“利器”。 它可提供關於正在運行的應用程序的各種信息,包括詳細的內存分配和再分配、事件生成、由代碼定義的自定義信息。 Austin LabVIEW程序架構師論壇的創建人之一Fabiola De la Cueva指出該工具包可用於調試已崩潰的應用程序,因為它是獨立於LabVIEW之外運行的。
圖7. 手動執行追蹤具有風險(圖片采自Oliver Widder)
專業的LabVIEW開發人員很慶幸,因為LabVIEW桌麵執行跟蹤工具包已包含在 NI開發者套件2011 之中,不會產生額外的費用。
單元測試
測試驅動開發(TDD) 是一種軟件工程技術,可幫助您從頭創建更好的代碼,同時它也是幫助您調試現有代碼的一個有效工具。
在TDD中(zhong),當(dang)您(nin)發(fa)現(xian)應(ying)用(yong)程(cheng)序(xu)存(cun)在(zai)漏(lou)洞(dong)時(shi),調(tiao)試(shi)流(liu)程(cheng)的(de)第(di)一(yi)個(ge)步(bu)驟(zhou)就(jiu)是(shi)創(chuang)建(jian)一(yi)個(ge)可(ke)重(zhong)現(xian)漏(lou)洞(dong)並(bing)導(dao)致(zhi)測(ce)試(shi)失(shi)敗(bai)的(de)單(dan)元(yuan)測(ce)試(shi)。隻(zhi)有(you)到(dao)那(na)時(shi)候(hou),您(nin)才(cai)確(que)實(shi)可(ke)以(yi)開(kai)始(shi)嚐(chang)試(shi)修(xiu)複(fu)問(wen)題(ti)。 如果單元測試通過,則表明您已清除了該漏洞。
圖8. 你在哪裏測試代碼?
這種漏洞修複方法需要費點時間,但是相比其他較不精確的方法,它具有以下幾個優點:
單元測試具有可追溯性,可完整顯示漏洞的發生過程以及您如何將漏洞隔離
您或其他開發者可隨時輕鬆驗證或重新驗證您的修複,而無需記住激活漏洞的詳細信息。
單元測試可在您的項目中與其他測試一起自動執行,因此漏洞如果再次出現,您可以立即知曉。