- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 ATL 项目,我需要在 CComObjectRootEx::FinalConstruct
中执行各种初始化例程。出于演示目的,请考虑以下实现:
HRESULT FinalConstruct()
{
return m_bInit ? S_OK : E_FAIL;
}
这应该向调用者返回适当的 HRESULT,指示对象的初始化是否成功。
但是,客户端在尝试创建服务器时总是收到 REGDB_E_CLASSNOTREG
而不是 E_FAIL
:
#include <Windows.h>
#import <finalconstructtest.dll>
int main()
{
HRESULT hr = CoInitialize(0);
{
finalconstructtestLib::IFCClassPtr p;
// Returns REGDB_E_CLASSNOTREG
hr = p.CreateInstance(__uuidof(finalconstructtestLib::FCClass));
}
CoUninitialize();
return 0;
}
然而,当我将类上下文更改为 CLSCTX_INPROC_SERVER
时,正确返回了预期的 HRESULT:
// Returns E_FAIL
hr = p.CreateInstance(__uuidof(finalconstructtestLib::FCClass), nullptr, CLSCTX_INPROC_SERVER);
我看过 this post,可以观察到类似的行为。但是,我似乎找不到类上下文影响 FinalConstruct
返回值的任何原因。这是有意的并且可能在某处记录了吗?
最佳答案
CoCreateInstance
API 不 promise 将内部故障代码转发给调用方。该实现更喜欢以自己的方式指示问题的根源,通过返回 REGDB_E_CLASSNOTREG
表示它无法完成实例化。这反过来又是正确的:它确实无法创建实例(并且问题与丢失接口(interface)、编码(marshal)处理、权限等无关)。也就是说,API 倾向于抑制内部故障代码,以将其替换为已记录的故障代码。
如果您更愿意指示特定的实例化失败,您最好在初始创建实例时成功,然后您可以实现一个具有属性或方法公开状态的接口(interface),或提供相关的 HRESULT
错误(有或没有 IErrorInfo
支持等)。
关于c++ - _com_ptr_t CreateInstance 返回 REGDB_E_CLASSNOTREG,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37546120/
这些调用有什么区别? 最佳答案 没有。 Assembly.CreateInstance 实际上在幕后调用了 Activator.CreateInstance。 在 Assembly.CreateIns
1)如果我们想在运行时创建给定类型的实例(因此使用后期绑定(bind)),那么我们需要调用 Activator.CreateInstance。但是如果Type类有这样的方法不是更高效吗?如果不出意外,
我想问一个问题来了解AppDomain和Activator之间的区别,我通过appdomain.CreateInstance加载了我的dll。但我意识到更多的方法来创建实例。因此,我何时何地选择这种方
这些调用有什么区别? 最佳答案 没有。 Assembly.CreateInstance 实际上在幕后调用了 Activator.CreateInstance。 在 Assembly.CreateIns
不,这不是关于泛型的问题。 我有一个工厂模式,其中包含几个带有内部构造函数的类(如果不通过工厂,我不希望它们被实例化)。 我的问题是 CreateInstance 失败并出现“没有为此对象定义无参数构
如果这个问题已经被问过和回答过,请原谅我。 给定一个类型为 T 的类,下面的区别是什么? T myObj = Activator.CreateInstance(); T myObj = typeof(
我正在尝试将插件系统与 .NET 放在一起,但我不确定我是否正确地做。系统的基础是一个特定的目录({apppath}/Plugins/)会有一堆预编译的DLL,我想用反射查看每一个,对于每个可用的类,
我需要获取 DataContext 的子类,我在某处找到了下面的函数,它确实找到了我的子类,但我无法实例化它:( public static IEnumerable GetSubclassesFo
这是我的构造函数: CMSATools::CMSATools() { m_pInterface = NULL; HRESULT hr; hr = m_pInterface.Cr
当我们使用 AppDomain.CreateInstance("Assembly name", Type name) 我的类继承自 MarshalByRefObject 内部发生了什么?它是否创建了一
我做了以下创建接口(interface)实例的方法。 static IFBIndexItem* CreateFBIndexItemPtr() { IFBIndexItemPtr pFBComW
我一直在我的一些代码中使用 Activator.CreateInstance()。使用它创建实例有任何风险吗? 最佳答案 好吧,你的代码存在弱类型的风险,你不会发现你不小心尝试将它与一个直到执行时才没
我想我缺乏了解,究竟发生了什么: 用户可以输入程序集的路径和对象类型,然后我尝试创建它的实例。 我的做法: Assembly a = Assembly.LoadFile(txtAsse
什么是System.Activator.CreateInstance,什么时候应该使用它? 最佳答案 它允许您创建其类型仅在运行时已知的对象的实例。因此,假设您有一些类(class) public c
有谁知道如何使用只有 1 个可选参数的构造函数来实例化一个类? 我都试过了 (T)Activator.CreateInstance(typeof(T), new object[] { Type.Mis
我们有一些使用 MSXML 的代码,这样做是为了创建 XML 文档对象: MSXML2::IXMLDOMDocumentPtr doc_in; doc_in.CreateInstance("Msxm
使用这段代码: public static class ChocolateFactory { private static Func Func { get; set; } static
我想将变量从一种形式传递到另一种形式。 这是 form2 中的构造函数: public Form2 (int getId,string getText) 在 form1 中我试图像这样传递变量 var
Activator.CreateInstance 和工厂有什么区别?它们可以互换使用吗?或者我们还需要工厂模式吗? 最佳答案 Activator.CreateInstance是一个静态方法,它使用该类
拥有Remember.cs: namespace Tasks { public class Remember : Task { new public string na
我是一名优秀的程序员,十分优秀!