|
Eine ganze Reihe von API-Funktionen muss ein genügend langer String übergeben werden, in dem sie die angeforderte und zurückzugebende Zeichenkette ablegen können. Nach der Rückgabe ist der String (auch "Puffer" genannt) jedoch nicht entsprechend der Länge der zurückgegebenen Zeichenkette passend gekürzt. Vielmehr wird hinter die gewünschte Information, wie in C üblich, ein Nullzeichen (Ascii 0 = vbNullChar) als Ende-Markierung gesetzt. Meistens wird von solchen API-Funktionen die tatsächliche Länge der in dem Puffer-String enthaltenen Information als Rückgabewert geliefert - allerdings nicht immer.
In Visual Basic können Sie die Position des Nullzeichens mittels der Funktion InStr ermitteln
nPos = InStr(Puffer, vbNullChar)
und den Puffer entsprechend kürzen:
Information = Left$(Puffer, nPos - 1)
Es kann aber vorkommen, dass zufällig die gesamte Länge des vorgesehenen Puffers mit der zurückgegebenen Information gefüllt wird - das Nullzeichen findet keinen Platz mehr und erübrigt sich. Die InStr-Funktion würde in diesem Fall 0 liefern, und Left$ würde mit der Angabe -1 einen Laufzeitfehler auslösen. Sie müssten diesen Fall gesondert behandeln:
If nPos Then
Information = Left$(Puffer, nPos - 1)
Else
Information = Puffer
End If
Etwas einfacher wäre es, wenn Sie nicht die Position des Nullzeichens ermitteln müssten, sondern gleich die tatsächliche Länge der Information im Puffer ermitteln könnten. Die API-Funktion lstrlen - Sie können sie in Anbetracht der Aufgabe per Alias auch in InStrNullChar umbenennen - liefert die gesuchte Länge. Daher können Sie nun statt dessen diese Funktion an die Stelle der um 1 verminderten Positionsangabe des Nullzeichens setzen. Noch einfacher wird die Abtrennung der in einem Puffer enthaltenen Information, wenn Sie das in eine einfache Funktion verpacken:
Public Declare Function InStrNullChar Lib "kernel32.dll" _
Alias "lstrlenA" (ByVal lpString As Any) As Long
Public Function TruncateNull(Text As String) As String
TruncateNull = Left$(Text, InStrNullChar(Text))
End Function
|