GetMenuStringA 函式 (winuser.h)
將指定功能表項的文字字串複製到指定的緩衝區。
語法
int GetMenuStringA(
[in] HMENU hMenu,
[in] UINT uIDItem,
[out, optional] LPSTR lpString,
[in] int cchMax,
[in] UINT flags
);
參數
[in] hMenu
類型:HMENU
功能表的句柄。
[in] uIDItem
類型:UINT
要變更的功能表項,由 uFlag 參數決定。
[out, optional] lpString
類型:LPTSTR
接收 Null 終止字串的緩衝區。 如果字串長度超過 lpString,則會截斷字串,並新增終止的 Null 字元。 如果 lpStringNULL,函式會傳回功能表字串的長度。
[in] cchMax
類型:int
要複製之字串的最大長度,以字元為單位。 如果字串超過 nMaxCount 參數中指定的最大值,則會截斷額外的字元。 如果 nMaxCount 為 0,函式會傳回功能表字串的長度。
[in] flags
類型:UINT
指出如何解譯 uIDItem 參數。 此參數必須是下列其中一個值。
價值 | 意義 |
---|---|
|
表示 uIDItem 提供功能表項的標識碼。 如果未指定 MF_BYCOMMAND 或 MF_BYPOSITION 旗標,則 MF_BYCOMMAND 旗標是預設旗標。 |
|
表示 uIDItem 為功能表項提供以零起始的相對位置。 |
傳回值
類型:int
如果函式成功,傳回值會指定複製到緩衝區的字元數,不包括終止的 Null 字元。
如果函式失敗,傳回值為零。
如果指定的專案不是類型為 MIIM_STRING 或 MFT_STRING,則傳回值為零。
言論
nMaxCount 參數必須大於文字字串中的字元數,以容納終止的 Null 字元。
如果 nMaxCount 為 0,函式會傳回功能表字串的長度。
安全性警告
lpString 參數是 TCHAR 緩衝區,而 nMaxCount 是字元的功能表字串長度。 調整這些參數的大小不正確可能會導致字串截斷,導致數據可能遺失。例子
如需範例,請參閱 建立使用者可編輯加速器。
注意
winuser.h 標頭會將 GetMenuString 定義為別名,根據 UNICODE 預處理器常數的定義,自動選取此函式的 ANSI 或 Unicode 版本。 混合使用編碼中性別名與非編碼中性的程序代碼,可能會導致編譯或運行時間錯誤不符。 如需詳細資訊,請參閱函式原型的
要求
要求 | 價值 |
---|---|
最低支援的用戶端 | Windows 2000 Professional [僅限傳統型應用程式] |
支援的最低伺服器 | Windows 2000 Server [僅限傳統型應用程式] |
目標平臺 | 窗戶 |
標頭 | winuser.h (包括 Windows.h) |
連結庫 | User32.lib |
DLL | User32.dll |
API 集 | ext-ms-win-ntuser-menu-l1-1-3 (在 Windows 10 版本 10.0.14393 中引進) |
另請參閱
概念
參考