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