मेरे पास एक वैश्विक चर है जो मेरे कस्टम वर्ग का एक उदाहरण है।
यदि ऑब्जेक्ट सेट किया गया है या मुझे इसे इनिशियलाइज़ करने की आवश्यकता है, तो मैं कैसे जांच करूँ?
मेरे पास एक वैश्विक चर है जो मेरे कस्टम वर्ग का एक उदाहरण है।
यदि ऑब्जेक्ट सेट किया गया है या मुझे इसे इनिशियलाइज़ करने की आवश्यकता है, तो मैं कैसे जांच करूँ?
जवाबों:
If obj Is Nothing Then
' need to initialize obj: '
Set obj = ...
Else
' obj already set / initialized. '
End If
या, यदि आप इसे अन्य तरीके से पसंद करते हैं:
If Not obj Is Nothing Then
' obj already set / initialized. '
Else
' need to initialize obj: '
Set obj = ...
End If
obj Is Nothing
करना जाँच के समान नहीं है IsNothing(obj)
! यह जाँचने के लिए सही वाक्यविन्यास के लिए धन्यवाद ... यह निश्चित नहीं है कि IsNothing()
अलग व्यवहार क्यों किया जाता है ...
Not (obj Is Nothing)
समझने में आसानी होती है Not obj Is Nothing
। मेरा दिमाग नहीं जानता कि एक "नहीं obj" क्या है!
ऐसा करने के लिए (संयुक्त राष्ट्र) सुरक्षित तरीका - यदि आप स्पष्ट विकल्प का उपयोग नहीं करने के साथ ठीक हैं - है ...
Not TypeName(myObj) = "Empty"
यदि वस्तु घोषित नहीं की गई है तो यह मामले को भी संभालती है। यह उपयोगी है यदि आप कुछ व्यवहार को बंद करने की घोषणा करना चाहते हैं ...
Dim myObj as Object
Not TypeName(myObj) = "Empty" '/ true, the object exists - TypeName is Object
'Dim myObj as Object
Not TypeName(myObj) = "Empty" '/ false, the object has not been declared
यह काम करता है क्योंकि VBA एक खाली वेरिएंट प्रकार के रूप में एक अघोषित चर को ऑटो-इंस्टेंट करेगा। यह व्यवहार का प्रबंधन करने के लिए एक सहायक बूलियन की आवश्यकता को समाप्त करता है।
Option Explicit
। यह समस्याओं के अलावा कुछ भी नहीं हासिल करता है। "स्विच" व्यवहार के लिए, सशर्त संकलन का उपयोग करें।