Variant 是一種特殊的數據類型,除了定長 String 數據及用戶定義類型外,可以包含任何種類的數據。Variant 也可以包含 Empty、Error、Nothing 及 Null等特殊值。可以用 VarType 函式或 TypeName 函式來決定如何處理 Variant 中的數據。
數值數據可以是任何整型或實型數,負數時範圍從 -1.797693134862315E308 到 -4.94066E-324,正數時則從 4.94066E-324 到 1.797693134862315E308。通常,數值Variant 數據保持為其 Variant 中原來的數據類型。例如,如果把一個 Integer賦值給 Variant,則接下來的運算會把此 Variant 當成 Integer 來處理。然而,如果算術運算針對含 Byte、Integer、Long 或 Single 之一的Variant 執行,並當結果超過原來數據類型的正常範圍時,則在 Variant 中的結果會提升到較大的數據類型。如 Byte 則提升到 Integer,Integer 則提升到 Long,而 Long和Single 則提升為 Double。當 Variant 變數中有 Currency、Decimal 及 Double 值超過它們各自的範圍時,會發生錯誤。
可以用 Variant 數據類型來替換任何數據類型,這樣會更有適應性。如果 Variant 變數的內容是數字,它可以用字元串來表示數字或是用它實際的值來表示,這將由上下文來決定,例如:
Dim MyVar As Variant
MyVar = 98052
在前面的例子中,MyVar 內有一實際值為 98052 的數值。像期望的那樣,算術運運算元可以對 Variant 變數運算,其中包含數值或能被解釋為數值的字元串數據。如果用 + 運運算元來將 MyVar 與其他含有數字的 Variant 或數值類型的變數相加,結果便是一算術和。
Empty 值用來標記尚未初始化(給定初始值)的Variant 變數。內含 Empty 的 Variant 在數值的上下文中表示 0,如果是用在字元串的上下文中則表示零長度的字元串 ("")。
不應將 Empty 與 Null 弄混。Null 是表示 Variant 變數確實含有一個無效數據。
在 Variant 中,Error 是用來指示在過程中出現錯誤時的特殊值。然而,不像對其他種類的錯誤那樣,程式並不產生普通的應用程式級的錯誤處理。這可以讓程式設計師,或應用程式本身,根據此錯誤值採取另外的行動。可以用 Cverr 函式將實數轉換為錯誤值來產生 Error 值。
變體類型Variant
變體類型Variant,能夠在運行期間動態的改變類型。變體類型能支持所有簡單的數據類型,如整型、浮點、字元串、布爾型、日期時間、貨幣及 OLE自動化對象等,不能夠表達Object Pascal對象。