Condividi tramite


Classe degli insiemi di Visual Basic

Un insieme consente di raggruppare una serie di elementi correlati. Esistono molti tipi di insiemi. Nelle applicazioni Visual Basic vengono spesso utilizzati gli insiemi predefiniti, ad esempio l'insieme Control.ControlCollection di un oggetto Form, restituito dalla proprietà Controls del form. È anche possibile creare insiemi personalizzati per organizzare e modificare gli oggetti.

Gli insiemi sono utili per tenere traccia degli oggetti di cui potrebbero essere necessarie la creazione e l'eliminazione dinamiche. Nel frammento di codice riportato di seguito viene illustrato come è possibile utilizzare il metodo Add di un oggetto di Visual Basic Collection per mantenere un elenco di oggetti widget creati dall'utente.

' Declare and create the Collection object.
Public widgetColl As New Microsoft.VisualBasic.Collection() 
' Create a new widget and add it to the widgetColl collection.
Private Sub makeAWidget()
    Dim tempWidget As New widget()
    widgetColl.Add(tempWidget) 
End Sub

Nell'esempio precedente l'insieme widgetColl organizza ed espone tutti gli oggetti widget creati mediante la routine makeAWidget. È possibile recuperare i riferimenti a ogni oggetto widget utilizzando l'indice dell'insieme. Le dimensioni dell'insieme vengono modificate automaticamente all'aggiunta di ogni nuovo oggetto widget. Per scorrere l'insieme, è possibile utilizzare l'Istruzione For Each...Next (Visual Basic). Se si desidera assegnare all'oggetto widget una chiave che possa essere utilizzata per recuperarlo, è possibile fornire una stringa di testo come secondo parametro del metodo Add.

Poiché tutti gli elementi dell'oggetto Collection di Visual Basic vengono archiviati con il tipo Object, è possibile aggiungere un elemento di un qualsiasi tipo di dati. Non esiste alcuna misura per impedire l'aggiunta di tipi di dati non appropriati. Per risolvere questo problema, è possibile utilizzare gli insiemi generici dello spazio dei nomi System.Collections.Generic. Per ulteriori informazioni, vedere Procedura: creare un insieme di oggetti (Visual Basic).

Creazione ed eliminazione di un oggetto Collection

La parola chiave Operatore New (Visual Basic) nella dichiarazione della variabile widgetColl determina la creazione di un oggetto Collection nel momento in cui il controllo passa all'istruzione di dichiarazione. Poiché Collection è una classe e non un tipo di valore, è necessario creare un'istanza della classe e conservare un riferimento a tale istanza in una variabile. Questa istanza è un oggetto di tipo Visual Basic Collection.

Come qualsiasi altro oggetto, un oggetto Collection viene contrassegnato per la Garbage Collection quando l'ultima variabile contenente un riferimento a tale oggetto viene impostata su Nothing (Visual Basic) oppure non rientra più nell'ambito. Quando l'oggetto viene recuperato tramite la Garbage Collection, tutti i riferimenti agli oggetti in esso contenuti vengono rilasciati. Per questo motivo, la variabile widgetColl nell'esempio precedente è dichiarata nella classe padre, in modo da essere disponibile per l'intera durata del programma.

Un insieme conserva i riferimenti agli oggetti da esso controllati, ma non contiene gli oggetti stessi. Di conseguenza, l'eliminazione di un oggetto Collection non determina l'eliminazione degli oggetti da questo controllati. Ogni singolo oggetto appartenente all'insieme continuerà a esistere fino a quando non verrà specificatamente contrassegnato per la Garbage Collection.

Utilizzo degli elementi

I servizi di base per l'aggiunta, l'eliminazione e il recupero degli elementi di un insieme dipendono da chiavi e indici. Una chiave è un valore String, che può essere un nome, un numero di patente, un numero di telefono o semplicemente un Integer convertito in una stringa. Il metodo Add consente di associare una chiave a un elemento, come descritto in Procedura: aggiungere, eliminare e recuperare elementi di un insieme (Visual Basic).

Un indice nella classe Collection è un Integer compreso tra 1 e il numero di elementi dell'insieme. La proprietà Count restituisce il numero corrente di elementi. Sebbene sia possibile specificare il valore iniziale dell'indice di un elemento utilizzando i parametri Before e After al momento della chiamata del metodo Add, il valore dell'indice potrebbe cambiare a causa dell'aggiunta o dell'eliminazione di altri elementi. Per ulteriori informazioni, vedere Add.

È possibile rimuovere un singolo elemento da un insieme passando la chiave o l'indice dell'elemento al metodo Remove. È possibile svuotare un insieme e rimuoverne tutti gli elementi utilizzando il metodo Clear.

Accesso agli elementi

È possibile passare un valore di chiave al metodo Contains per verificare se un insieme contiene un elemento con tale chiave. È possibile recuperare un elemento passando la chiave o l'indice dell'elemento alla proprietà Item.

Per scorrere gli elementi di un insieme è possibile utilizzare i valori di indice e la proprietà Item oppure l'Istruzione For Each...Next (Visual Basic). Nell'esempio riportato di seguito vengono illustrati due modi per assegnare un aumento di stipendio del 10% a tutti i dipendenti inclusi in un insieme di oggetti employee, presupponendo che la variabile employeesColl contenga un riferimento a un oggetto Collection.

Option Strict On
' The following alternative uses the Count and Item properties.
Dim emp As employee
For counter As Integer = 1 To employeesColl.Count 
    emp = CType(employeesColl.Item(counter), employee)
    emp.payRate *= 1.1
Next counter
' The following alternative uses the For Each...Next statements.
For Each emp As employee In employeesColl
    emp.payRate *= 1.1
Next emp

Tuttavia, se sono stati aggiunti a employeesColl uno o più elementi non di tipo employee, il ciclo For Each genererà un'eccezione ArgumentException in fase di esecuzione.

Tipo di dati degli elementi

Tutti gli elementi di un oggetto Collection di Visual Basic vengono archiviati con il tipo di dati Object. Di conseguenza, i tipi di dati che possono essere aggiunti a un oggetto Collection corrispondono a quelli che possono essere archiviati in una variabile Object e includono tipi di dati, oggetti e matrici standard, oltre a strutture e istanze di classe definite dall'utente.

Dal momento che ciascun elemento nell'oggetto Collection viene archiviato come Object, la proprietà Item restituisce un valore Object. Per utilizzare l'elemento nel codice, in genere è necessario eseguire la conversione da Object al tipo di dati dell'elemento in fase di esecuzione. Il modo in cui questa operazione viene eseguita dipende dall'impostazione dell'opzione di controllo dei tipi nell'Istruzione Option Strict.

Conversione implicita dal tipo Object

Se Option Strict è impostata su Off, è possibile convertire implicitamente un elemento di Collection nel tipo di dati appropriato, come illustrato nel seguente esempio.

Option Strict Off
Dim sampleColl As New Microsoft.VisualBasic.Collection()
Dim sampleString As String = "This is a string"
Dim aString As String
sampleColl.Add(sampleString)
' The following statements convert the collection item to a string.
Try
    aString = sampleColl.Item(1) 
Catch ex As Exception
    ' Insert code to run if the collection item cannot be converted to String.
End Try

Conversione esplicita dal tipo Object

Se Option Strict è impostata su On, è necessario eseguire una conversione esplicita da Object al tipo di dati dell'elemento in fase di esecuzione. Per ottenere un elemento da Item in questo modo, è possibile utilizzare la Funzione CType (Visual Basic) per eseguire la conversione, come illustrato nel seguente esempio.

Option Strict On
Dim sampleColl As New Microsoft.VisualBasic.Collection()
Dim sampleString As String = "This is a string"
Dim aString As String
sampleColl.Add(sampleString)
' The following statements convert the collection item to a string.
Try
    aString = CType(sampleColl.Item(1), String) 
Catch ex As Exception
    ' Insert code to run if the collection item cannot be converted to String.
End Try

Servizi aggiuntivi

Le proprietà e i metodi dell'oggetto Collection forniscono soltanto i servizi di base relativi agli insiemi. Il metodo Add, ad esempio, non consente di controllare il tipo di elemento aggiunto a un insieme, operazione necessaria per assicurare che l'insieme contenga un unico tipo di elemento. Se è possibile garantire tale requisito nel metodo Add, si otterrà un insieme fortemente tipizzato e non sarà necessario convertire il valore restituito dalla proprietà Item nel relativo tipo di dati in fase di esecuzione, con conseguente aumento delle prestazioni.

Per fornire una funzionalità più affidabile e aggiungere proprietà, metodi ed eventi, è possibile creare una classe di insiemi personalizzata, come descritto in Procedura: definire insiemi nelle classi (Visual Basic).

Vedere anche

Riferimenti

Collection

Concetti

Matrici in Visual Basic

Insiemi in Visual Basic