IPersistMessage::GetLastError

适用于:Outlook 2013 | Outlook 2016

返回一个 MAPIERROR 结构,该结构包含有关窗体对象中上一个错误的信息。

HRESULT GetLastError(
  HRESULT hResult,
  ULONG ulFlags,
  LPMAPIERROR FAR * lppMAPIError
);

参数

hResult

[in]包含上一个方法调用中生成的错误值的 HRESULT 数据类型。

ulFlags

[in]控制返回的字符串类型的标志的位掩码。 可以设置以下标志:

MAPI_UNICODE

lppMAPIError 参数中返回的 MAPIERROR 结构中的字符串采用 Unicode 格式。 如果未设置MAPI_UNICODE标志,则字符串采用 ANSI 格式。

lppMAPIError

[out]指向 MAPIERROR 结构的指针的指针,该结构包含错误的版本、组件和上下文信息。 如果表单无法为 MAPIERROR 结构提供适当的信息,则可以将 lppMAPIError 参数设置为 NULL。

返回值

S_OK

调用成功,并返回了预期的值。

MAPI_E_BAD_CHARWIDTH

MAPI_UNICODE标志已设置,通讯簿提供程序不支持 Unicode,或者未设置MAPI_UNICODE,并且通讯簿提供程序仅支持 Unicode。

备注

Form 对象实现 IPersistMessage::GetLastError 方法,以提供有关先前失败的方法调用的信息。 表单查看者可以通过在对话框中包括 MAPIERROR 结构中的数据来向用户提供有关错误的详细信息。

调用 GetLastError 不会影响窗体的状态。 当 GetLastError 返回时,窗体将保持调用之前的状态。

给调用方的说明

如果窗体提供 MAPIERROR 结构,则仅当 GetLastError 返回S_OK时,才能使用 lppMAPIError 参数指向的 MAPIERROR 结构。 有时,窗体无法确定最后一个错误是什么,或者无法再报告有关该错误的内容。 在这种情况下,窗体改为在 lppMAPIError 中返回指向 NULL 的指针。

有关 GetLastError 方法的详细信息,请参阅 MAPI 扩展错误

另请参阅

MAPIERROR

MAPIFreeBuffer

IPersistMessage : IUnknown