1

我想将一个字符串作为输入/输出参数传递给一个过程。我知道这不像 VBA 通常可以工作,但这是因为特殊情况。我有一个已经存在的代码生成器工具 - 为文件格式解析器生成代码。而且我不想破解这段代码。生成的语法可以很容易地转换为 vba 使用 text replace 这没什么大不了的(我已经这样做了)。但是很难将程序更改为功能。

我想出的是如何通过传递它的指针来扩展一个字符串。但是如何将字符附加到字符串中?

Option Explicit

Private Declare Sub CopyMemory Lib "kernel32" _
Alias "RtlMoveMemory" (Destination As Any, Source As Any, _
    ByVal length As Long)

Private Declare Function lstrlenA Lib "kernel32" _
   (ByVal lpString As Long) As Long

Private Declare Function lstrlenW Lib _
  "kernel32" (ByVal lpString As Long) As Long


Sub AppendString(i_pt As Long, i_what As String)
    Dim strLentgh As Long                  ' variable to hold the length of string
    Dim ptrLengthField As Long             ' pointer to 4-byte length field

    ' get the length of the string
    ptrLengthField = i_pt - 4              ' length field is 4 bytes behind
    CopyMemory strLentgh, ByVal ptrLengthField, 4

    ' extend the String length
    strLentgh = strLentgh + (Len(i_what) * 2)
    CopyMemory ByVal ptrLengthField, strLentgh&, 4

    ' How to apped the string?
    ' CopyMemory ByVal i_pt, ????
End Sub

Sub test2()
    Dim str As String
    Dim sPtr As Long

    str = "hello"
    sPtr = strPtr(str)

    Debug.Print Len(str)
    Call AppendString(sPtr, " there")
    Debug.Print Len(str)
    Debug.Print str
End Sub
4

1 回答 1

0

VBA 可以本机执行此操作

Sub AppendString(byref str as string, i_what As String)
    str = str & i_what
end sub

去测试

Sub Test()
    Dim s As String

    s = "Hello"

    AppendString s, " World"
    Debug.Print s
End Sub
于 2011-05-18T20:10:13.677 回答