ICLRHostBindingPolicyManager::ModifyApplicationPolicy 方法

修改指定的程序集的绑定策略,并创建该策略的新版本。

HRESULT  ModifyApplicationPolicy (
    [in] LPCWSTR     pwzSourceAssemblyIdentity, 
    [in] LPCWSTR     pwzTargetAssemblyIdentity,
    [in] BYTE       *pbApplicationPolicy,
    [in] DWORD       cbAppPolicySize,
    [in] DWORD       dwPolicyModifyFlags,
    [out, size_is(*pcbNewAppPolicySize)] BYTE *pbNewApplicationPolicy, 
    [in, out] DWORD *pcbNewAppPolicySize
);

参数

  • pwzSourceAssemblyIdentity
    [in] 要修改的程序集的标识。

  • pwzTargetAssemblyIdentity
    [in] 已修改程序集的新标识。

  • pbApplicationPolicy
    [in] 一个指向缓冲区的指针,该缓冲区包含要修改的程序集的绑定策略数据。

  • cbAppPolicySize
    [in] 要替换的绑定策略的大小。

  • dwPolicyModifyFlags
    [in] EHostBindingPolicyModifyFlags 值的逻辑“或”组合,指示重定向控制。

  • pbNewApplicationPolicy
    [out] 一个指向包含新绑定策略数据的缓冲区的指针。

  • pcbNewAppPolicySize
    [in, out] 一个指向新绑定策略缓冲区大小的指针。

返回值

HRESULT

说明

S_OK

策略修改成功。

E_INVALIDARG

pwzSourceAssemblyIdentity 或 pwzTargetAssemblyIdentity 是 null 引用。

ERROR_INSUFFICIENT_BUFFER

pbNewApplicationPolicy 太小。

HOST_E_CLRNOTAVAILABLE

公共语言运行时 (CLR) 尚未加载到进程中或者处于无法运行托管代码或成功处理调用的状态。

HOST_E_TIMEOUT

调用超时。

HOST_E_NOT_OWNER

调用方不拥有锁。

HOST_E_ABANDONED

事件在被阻止的线程或纤程正在等待它时被取消。

E_FAIL

发生了未知的灾难性故障。 在某方法返回 E_FAIL 后,CLR 便无法再在进程中使用。 对宿主方法的后续调用都将返回 HOST_E_CLRNOTAVAILABLE。

备注

ModifyApplicationPolicy 方法可调用两次。 第一次调用应为 pbNewApplicationPolicy 参数提供一个 Null 值。 此调用将返回 pcbNewAppPolicySize 必需的值。 第二次调用应为 pcbNewAppPolicySize 提供此值,并为 pbNewApplicationPolicy 指向一个该大小的缓冲区。

要求

**平台:**请参见 .NET Framework 系统要求

**头文件:**MSCorEE.h

**库:**作为一项资源包含在 MSCorEE.dll 中

**.NET Framework 版本:**4、3.5 SP1、3.5、3.0 SP1、3.0、2.0 SP1、2.0

请参见

参考

ICLRHostBindingPolicyManager 接口