Procedura: definire un operatore (Visual Basic)

Se è stata definita una classe o una struttura, è possibile definire il comportamento di un operatore standard ( ad esempio *, <> o And) quando uno o entrambi gli operandi sono del tipo della classe o della struttura.

Definire l'operatore standard come routine di operatore all'interno della classe o della struttura. Tutte le routine di operatore devono essere PublicShared.

La definizione di un operatore in una classe o struttura è anche chiamata overload dell'operatore.

Esempio

Nell'esempio seguente viene definito l'operatore + per una struttura denominata height. La struttura usa altezze misurate in piedi e pollici. Un pollice corrisponde a 2,54 centimetri e un piede equivale a 12 pollici. Per garantire valori normalizzati (pollici e 12,0), il costruttore esegue l'operazione aritmetica modulo 12. L'operatore + usa il costruttore per generare valori normalizzati.

Public Shadows Structure height
    ' Need Shadows because System.Windows.Forms.Form also defines property Height.
    Private feet As Integer
    Private inches As Double
    Public Sub New(ByVal f As Integer, ByVal i As Double)
        Me.feet = f + (CInt(i) \ 12)
        Me.inches = i Mod 12.0
    End Sub
    Public Overloads Function ToString() As String
        Return Me.feet & "' " & Me.inches & """"
    End Function
    Public Shared Operator +(ByVal h1 As height, 
                             ByVal h2 As height) As height
        Return New height(h1.feet + h2.feet, h1.inches + h2.inches)
    End Operator
End Structure

È possibile testare la struttura height con il codice seguente.

Public Sub consumeHeight()
    Dim p1 As New height(3, 10)
    Dim p2 As New height(4, 8)
    Dim p3 As height = p1 + p2
    Dim s As String = p1.ToString() & " + " & p2.ToString() &
          " = " & p3.ToString() & " (= 8' 6"" ?)"
    Dim p4 As New height(2, 14)
    s &= vbCrLf & "2' 14"" = " & p4.ToString() & " (= 3' 2"" ?)"
    Dim p5 As New height(4, 24)
    s &= vbCrLf & "4' 24"" = " & p5.ToString() & " (= 6' 0"" ?)"
    MsgBox(s)
End Sub

Vedi anche