getServiceDisplayNameA 函式 (winsvc.h)
擷取指定服務的顯示名稱。
語法
BOOL GetServiceDisplayNameA(
[in] SC_HANDLE hSCManager,
[in] LPCSTR lpServiceName,
[out, optional] LPSTR lpDisplayName,
[in, out] LPDWORD lpcchBuffer
);
參數
[in] hSCManager
服務控制管理員資料庫的句柄,如 OpenSCManager 函式所傳回。
[in] lpServiceName
服務名稱。 此名稱與服務的登錄機碼名稱相同。 最好選擇少於 256 個字元的名稱。
[out, optional] lpDisplayName
接收服務顯示名稱之緩衝區的指標。 如果函式失敗,此緩衝區會包含空字串。
此陣列的大小上限為4K位元組。 若要判斷所需的大小,請為此參數指定 NULL,並針對 lpcchBuffer 參數指定 0。 函式將會失敗,而且 GetLastError 會 傳回ERROR_INSUFFICIENT_BUFFER。 lpcchBuffer 參數將會收到所需的大小。
這個參數可以使用下列格式來指定本地化字串:
@[path]dllname,-strID
標識符 strID 的字串會從 dllname 載入;路徑是選擇性 的 。 如需詳細資訊,請參閱 RegLoadMUIString。
Windows Server 2003 和 Windows XP: 在 Windows Vista 之前,不支援當地語系化字串。
[in, out] lpcchBuffer
變數的指標,指定 TCHARs 中 lpDisplayName 指向的緩衝區大小。
在輸出時,此變數會接收服務顯示名稱的大小,以字元為單位,不包括 Null 終止字元。
如果 lpDisplayName 指向的緩衝區太小而無法包含顯示名稱,則函式不會儲存它。 當函式傳回時, lpcchBuffer 會包含服務顯示名稱的大小,不包括 Null 終止字元。
傳回值
如果函式成功,則傳回值為非零。
如果此函式失敗,則傳回值為零。 若要取得擴充的錯誤資訊,請呼叫 GetLastError。
備註
服務有兩個名稱:服務名稱和顯示名稱。 服務名稱是登錄中服務機碼的名稱。 顯示名稱是出現在 [服務] 控制面板應用程式中的使用者易記名稱,且會與 NET START 命令搭配使用。 若要將服務名稱對應至顯示名稱,請使用 GetServiceDisplayName 函式。 若要將顯示名稱對應至服務名稱,請使用 GetServiceKeyName 函式。
注意
winsvc.h 標頭會將 GetServiceDisplayName 定義為別名,根據 UNICODE 預處理器常數的定義,自動選取此函式的 ANSI 或 Unicode 版本。 混合使用編碼中性別名與非編碼中性的程序代碼,可能會導致編譯或運行時間錯誤不符。 如需詳細資訊,請參閱 函式原型的慣例。
規格需求
需求 | 值 |
---|---|
最低支援的用戶端 | Windows XP [僅限傳統型應用程式] |
最低支援的伺服器 | Windows Server 2003 [僅限桌面應用程式] |
目標平台 | Windows |
標頭 | winsvc.h (包含 Windows.h) |
程式庫 | Advapi32.lib |
Dll | Advapi32.dll |