Solved

How do I initialize/utilize an arraylist and a hashtable defined in a different class?

Posted on 2008-06-26
4
1,060 Views
Last Modified: 2010-07-27
Friends,

I have a routine where I need to clear 2 arrays and a hashtable, but they are defined in a different class (frmTimelineViewer).  

I tried doing a Dim aFFOrder as New... But it isn't available from the list of options when I type frmTimelineViewer.

How do I intialize/utilize these arraylists and the hashtable from another class?

Regards,
Eric
Public Sub ProcessFFData(ByVal Lap As Integer, ByVal RunID As Integer)

        frmTimelineSerial.lvFF.Clear()

        frmTimelineSerial.lvFF.Columns.Add("No")

        frmTimelineSerial.FFOrderArray.Clear() 'If I try to run this or any of the following 2 lines, I get a NullReferenceException Error. 

        frmTimelineSerial.FFOrderDoNotIncludeHT.Clear()

        frmTimelineSerial.FFOrderHT.Clear()
 

        Using TableAdapter As New ReportingDataTableAdapters.FFOrderTableAdapter()

            Using DataTable As ReportingData.FFOrderDataTable = TableAdapter.GetData(Lap, RunID)

                Dim Row As ReportingData.FFOrderRow

                Dim li As ListViewItem

                Dim i As Integer = 0

                For Each Row In DataTable

                    li = frmTimelineSerial.lvFF.Items.Add(Row.CarNumber)

                    frmTimelineSerial.FFOrderArray.Add(Row.CarNumber) ' The same thing happens with these two lines.

                    frmTimelineSerial.FFOrderHT.Add(Row.CarNumber, i)

                Next

            End Using

        End Using

    End Sub

Open in new window

0
Comment
Question by:indy500fan
  • 2
  • 2
4 Comments
 
LVL 85

Accepted Solution

by:
Mike Tomlinson earned 500 total points
ID: 21877405
Either...

(1) Pass a reference to those objects into your sub.
(2) Make them shared so you can access them from anywhere.
(3) Place them in a Module as Public so they can be accessed from anywhere.

There are other methods depending on your situation...
0
 

Author Comment

by:indy500fan
ID: 21877449
Would you agree declaring them as the following would be wrong?  Should I declare them as New or is that a bad idea?

   Public Shared FFOrderArray As New ArrayList

    Public Shared FFNewOrderArray As New ArrayList

    Public Shared FFOrderDoNotIncludeInOrderArray As New ArrayList

    Public Shared FFOrderHT As New Hashtable

    Public Shared FFOrderDoNotIncludeHT As New Hashtable
0
 

Author Comment

by:indy500fan
ID: 21877491
Duh, I just need the new clause.  I had brainfade and wasn't thinkin clearly.

Thanks for your help!
0
 
LVL 85

Expert Comment

by:Mike Tomlinson
ID: 21877504
"Wrong" is really only relative to YOUR situation.

If those items only ever need ONE instance of them across all forms then it's fine.

You could then access them with:

    frmTimelineViewer.FFOrderArray

etc...

If you need a seperate copy of each one for every instance of the form then this is not a viable approach.
0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

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

Article by: Kraeven
Introduction Remote Share is a simple remote sharing tool, enabling you to see, add and remove remote or local shares. The application is written in VB.NET targeting the .NET framework 2.0. The source code and the compiled programs have been in…
Introduction As chip makers focus on adding processor cores over increasing clock speed, developers need to utilize the features of modern CPUs.  One of the ways we can do this is by implementing parallel algorithms in our software.   One recent…
This Micro Tutorial demonstrates using Microsoft Excel pivot tables, how to reverse engineer competitors' marketing strategies through backlinks.
Many functions in Excel can make decisions. The most simple of these is the IF function: it returns a value depending on whether a condition you describe is true or false. Once you get the hang of using the IF function, you will find it easier to us…

920 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

Need Help in Real-Time?

Connect with top rated Experts

16 Experts available now in Live!

Get 1:1 Help Now