GetWindowTextLengthW 函数 (winuser.h)
检索指定窗口的标题栏文本的长度(如果窗口具有标题栏)。 如果指定的窗口是控件,该函数将检索控件中文本的长度。 但是,GetWindowTextLength 无法检索其他应用程序中编辑控件的文本长度。
语法
int GetWindowTextLengthW(
[in] HWND hWnd
);
参数
[in] hWnd
类型:HWND
窗口或控件的句柄。
返回值
类型:int
如果函数成功,则返回值为文本的长度(以字符为单位)。 在某些情况下,此值可能大于文本的长度(请参阅“备注”。
如果窗口没有文本,则返回值为零。
函数失败由零的返回值和 GetLastError 结果指示为非零。
注意
此函数未清除最新的错误信息。 若要确定成功或失败,请通过调用
言论
如果目标窗口归当前进程所有,GetWindowTextLength 会导致 WM_GETTEXTLENGTH 消息发送到指定的窗口或控件。
在某些情况下,GetWindowTextLength 函数可能会返回大于文本实际长度的值。 这发生在 ANSI 和 Unicode 的某些混合体中,这是因为系统允许文本中可能存在双字节字符集 (DBCS) 字符。 但是,返回值始终至少与文本的实际长度一样大;因此,始终可以使用它来指导缓冲区分配。 当应用程序同时使用 ANSI 函数和使用 Unicode 的常见对话时,可能会发生此行为。 当应用程序将 ANSI 版本的 GetWindowTextLength 与窗口过程为 Unicode 的窗口一起使用,或者将 GetWindowTextLength 的 Unicode 版本 与窗口过程为 ANSI 的窗口一起使用时,也会发生这种情况。 有关 ANSI 和 ANSI 函数的详细信息,请参阅函数原型
若要获取文本的确切长度,请使用 WM_GETTEXT、LB_GETTEXT或 CB_GETLBTEXT 消息,或 GetWindowText 函数。
注意
winuser.h 标头将 GetWindowTextLength 定义为一个别名,该别名根据 UNICODE 预处理器常量的定义自动选择此函数的 ANSI 或 Unicode 版本。 将中性编码别名与不中性编码的代码混合使用可能会导致编译或运行时错误不匹配。 有关详细信息,请参阅函数原型的
要求
要求 | 价值 |
---|---|
最低支持的客户端 | Windows 2000 Professional [仅限桌面应用] |
支持的最低服务器 | Windows 2000 Server [仅限桌面应用] |
目标平台 | 窗户 |
标头 | winuser.h (包括 Windows.h) |
库 | User32.lib |
DLL | User32.dll |
API 集 | ext-ms-win-ntuser-window-l1-1-1(在 Windows 8.1 中引入) |
另请参阅
概念
其他资源
参考