Solved

Difference between an array defined with "Static" keyword and "Dim" keyword?

Posted on 2010-08-31
3
601 Views
Last Modified: 2012-05-10
hi,

Is there any difference between the following two statements?

Static strarray() As String
Dim strarray() As String

I tried to change Dim strarray() As String to Static strarray() As String in the below code. I dont see the difference this way. Can anybody explain? Thanks
       


Private Sub Form_Load()
    Dim strarray() As String
        
    ReDim strarray(2) As String
    
    strarray(0) = "1"
    strarray(1) = "2"
           
    For i = 0 To UBound(strarray) - 1
        MsgBox (strarray(i))
    Next
End Sub

Open in new window

0
Comment
Question by:ipjyo
  • 2
3 Comments
 
LVL 8

Accepted Solution

by:
thoffman earned 500 total points
ID: 33572211
Static causes the variable to keep the value between function calls. It basically "remembers" the value of the array when the function exits instead of resetting it each time it's called. I've modified the function to show how it would behave (I changed the variable to a long to make it easier to see).
 
If you keep it as dim, the code will return the following every time it's run:
1
2

On the other hand, if you make it static, the first time it's run, it returns:
1
2

Then, the second time it's run, since strarray(0) is set to 1, it returns:
2
3

And so on...

Private Sub Form_Load()
    Dim strarray() As long
        
    ReDim strarray(2) As long
    
    strarray(0) = strarray(0) + 1
    strarray(1) = strarray(0) + 1
           
    For i = 0 To UBound(strarray) - 1
        MsgBox (strarray(i))
    Next
End Sub

Open in new window

0
 
LVL 8

Expert Comment

by:thoffman
ID: 33572224
By the way, I just realized that you had that in a Form_Load, so static wouldn't make much sense since the function is only called once anyway. It would be better in a button click function.
0
 

Author Comment

by:ipjyo
ID: 33573070
Thanks for the clarification.
0

Featured Post

On Demand Webinar - Networking for the Cloud Era

This webinar discusses:
-Common barriers companies experience when moving to the cloud
-How SD-WAN changes the way we look at networks
-Best practices customers should employ moving forward with cloud migration
-What happens behind the scenes of SteelConnect’s one-click button

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

The debugging module of the VB 6 IDE can be accessed by way of the Debug menu item. That menu item can normally be found in the IDE's main menu line as shown in this picture.   There is also a companion Debug Toolbar that looks like the followin…
I was working on a PowerPoint add-in the other day and a client asked me "can you implement a feature which processes a chart when it's pasted into a slide from another deck?". It got me wondering how to hook into built-in ribbon events in Office.
Show developers how to use a criteria form to limit the data that appears on an Access report. It is a common requirement that users can specify the criteria for a report at runtime. The easiest way to accomplish this is using a criteria form that a…
This lesson covers basic error handling code in Microsoft Excel using VBA. This is the first lesson in a 3-part series that uses code to loop through an Excel spreadsheet in VBA and then fix errors, taking advantage of error handling code. This l…

749 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question