返回字符串的当前内存地址.
Address := StrPtr(Value)
类型: 字符串
类型: 整数
该函数返回 Value 的当前内存地址.
一个地址的寿命以及对它进行哪些操作是有效的, 取决于 Value 是如何传递给这个函数的. 有三种不同的情况, 如下面的示例代码所示. 在所有情况下, 如果字符串 不会 被修改, 返回值可以 直接 传递给 DllCall 函数或 SendMessage.
Ptr := StrPtr(MyVar)
如果 Value 是一个变量引用(如 MyVar
)(而不是内置变量), 那么返回值就是变量内部字符串缓冲的内存地址. VarSetStrCapacity(&MyVar)
以字符为单位 返回缓冲的大小, 不包括终止的空字符.
这个地址应该被认为是有效的, 直到变量被释放或被重新赋值(通过赋值运算符或将其传递给内置函数). 在函数返回后, 函数的局部变量的内容地址是无效的, 因为局部变量是自动释放的.
该地址可以存储在 structure(结构体) 或其他变量中, 并间接传递给 DllCall 或 SendMessage 或以其他方式使用, 只要它仍然有效, 如上所述.
脚本可以通过将地址间接传递给 NumPut, DllCall 或 SendMessage 来改变字符串的值. 如果以这种方式改变了字符串的长度, 必须通过调用 VarSetStrCapacity(&MyVar, -1)
来更新变量的内部长度属性.
Ptr := StrPtr("literal string")
原义字符串的地址是有效的, 直到程序退出. 脚本不应试图修改该字符串. 该地址可以存储在结构体或其他变量中, 并间接传递给 DllCall 或 SendMessage 或以其他方式使用.
SendMessage 0x000C, 0, StrPtr(A_ScriptName " changed this title"),, "A"
临时字符串的地址只在整体表达式的计算或函数调用语句完成之前有效, 之后不得使用. 对于上面的例子, 地址在 SendMessage 返回之前都是有效的. 以下所有内容都会产生临时字符串:
如果上面没有明确说明, 可以安全的假定字符串是临时的.
VarSetStrCapacity, DllCall, SendMessage, Buffer 对象, NumPut, NumGet