labview的數(shù)據(jù)類型----通過類型描述符提取控件名稱(LABEL)
先看看第一個CASE: 條件是:"I8".."CXT", "Boolean", "Variant" ,這說明從I8--->"CXT",包括BOOLEAN VARIANT類型描述符的結(jié)構(gòu)都是類似的.看看I8 和BOOLEAN的類型描述符的內(nèi)容,我們分析一下.
I8和BOOLEAN除了類型碼不同(0X01,0X21),其它結(jié)構(gòu)完全相同.第一個字(兩個字節(jié))表示存儲結(jié)構(gòu)的長度,*2表示字節(jié)數(shù).
0X40是LABVIEW保留的.第三個字的高位字節(jié)0X02表示名稱包括兩個字節(jié)(字符,ASCII).可以看出它的標簽是aa.
前4個字節(jié)(兩個字I16)是類型描述符的頭部信息,第5個字節(jié)0X02表示名稱的長度是2個字符,這樣,通過把類型描述符的結(jié)構(gòu)轉(zhuǎn)換成U8數(shù)組或者16進制字符串,就可以拆分出它的標簽信息.
左邊的圖通過鑄模函數(shù),把I16數(shù)組轉(zhuǎn)換成16進制字符串,通過一個Get PString(有點類似C指針),提取出標簽.
右邊的圖是Get PString的程序框圖,因為以后要經(jīng)常用到,重點解釋一下.
我們前文談到過,字符串和U8數(shù)組在內(nèi)存中的存儲形式是完全相同的,所以操作字符串和操作U8數(shù)組是等價的.
表示名稱長度信息在第5個字節(jié)中,所以首先用索引數(shù)組取出第5個字節(jié)(索引4,ARRAY從索引0開始)
通過截取字符串函數(shù),字符串長度參數(shù)是剛剛從數(shù)組中取出的,開始位置是4+1(去掉長度字節(jié)),至此,完成了
提取標簽信息.
枚舉類型的類型描述符結(jié)構(gòu)是不同于I8,U8的,下一個CASE是用于提取ENUM的標簽的.首先看看ENUM的類型描述符的組成結(jié)構(gòu).
類型描述符號的頭部信息都是類似的,由長度,類型碼組成.重點看第5個字節(jié),這里的0X03表示枚舉由3個元素組成,以下分別是第一個元素標簽(這里稱名稱可能更合適)的長度(字符個數(shù))和名稱的相應的ASCII,分析可以得到,第一個元素名稱包括兩個字符,41,41,即AA,第二個元素包括兩個字符,42,42,即BB,第三個包括兩個字符43,43,既CC.值得注意的是接下來并不是標簽的長度,而是用00來填充補位,而下一個字的高位字節(jié)才表示標簽的長度,長度為2,標簽字符6D?。叮偶磎n.
看看OPENG是如何提?。牛危眨蜆撕灥模?p>
頭部信息中的ELEMENTS表示一共三個元素,所以利用一個三次FOR循環(huán),計算出標簽的索引,注意有一個加余數(shù)的過程,這個就是解決上面的填充0問題,這個0不體現(xiàn)在長度字節(jié)中的.然后再次調(diào)用Get PString就得到了枚舉的標簽.實際上,上面的過程也可以得到枚舉中的每個元素的名稱.
結(jié)構(gòu)基本相同,從第9個字符開始是標簽長度,接下來是ASCII,所以與U8,BOOLEAN調(diào)用除了開始索引位置不同,調(diào)用方法完全相同.
其它的,比如數(shù)組,簇等,就不多介紹了.
評論