重载返回的类(例如 xmlpp 中的 DomParser's 文档)
Overloading a returned class (eg DomParser's Document in xmlpp)
在中断了十年之后,我又回到了C++领域,发现在我离开的时候发生了很多事情,我认为我错过了现代框架的一些基本内容。
我有一份文件。这是我的文件。它是一个xml文档,但具有额外的功能,因此,从设计的角度来看,它应该派生自xmlpp::document。
然而,它是从一个源代码加载的,这意味着要经过xmlpp::DomParser,它返回一个基本的xmlpp::Document对象——而不是我想要的。
因为我的类包含额外的数据,所以基本的强制转换无法做到这一点。我不想仅仅将文档存储为我自己类的属性,因为在许多情况下我都直接处理它。
在最坏的情况下,我可以将根节点导入到我自己的对象中,但这似乎有些过头了,我觉得我错过了一些基本的东西。框架中是否有我忽略的东西?
谢谢。
您可以创建一个装饰器,或者简单地重载复制(如果是c++11
,则移动)赋值运算符和构造函数,这样您的对象将从您获得的xmlpp::Document
创建为该类型的子类。
我对此做了很多研究,答案分为两部分。
我是正确的,与许多其他C++平台不同,有一种简单的方法可以重载现有的Gtkmm类。
Gtk的理念是,实际的对象是GObject句柄,C++包装器只是众多(Python、Perl等)中的一个。因此,甚至属性都是通过Glib::Object::set_property(名称,T&value)和Glib::Object::get_property。实际上,GObject是真正的"类"。
由于派生类和原始类共享一个通用的GObject格式(在本例中为libxml2,_xmlDoc对象),因此标准GtkObject的wrap函数应该能够转移所有权,因此:
GtkObject *pObj = pGtkObjectBasedClass->c_obj ();
pMyObjectBasedClass->wrap (pObj); // Automatically increases ref count of object
delete pGtkObjectBasedClass;
这是通用的方法。在xmlpp的情况下,没有实现"wrap"函数,它是从Noncompable派生的。然而,在最新的更新中,将现有对象或文档作为参数的构造函数现在是公共的,不再是私有的,因此现在应该可以进行传输。非标准,但应达到相同效果。
不,代码实例化了一个xmlpp::Document,所以在不更改libxml++的实际代码的情况下,无法使用libxml++实现这一点。
无论如何,我并没有真正看到从xmlpp::Document派生出MyDocument的好处。您不会试图覆盖xmlpp::Document的任何行为,也不会试图实现任何类型的多态性,也不会编写更少的代码。事实上,只要使用xmlpp::Document作为Document类的成员变量,就会向Document类的用户隐藏较低级别的XMLneneneba API。
- 正在查找文档以获得PS4平台的C++中的设备信息
- 如何在文档文件夹中创建目录
- 当Microsoft文档仅包含 C# 示例时,如何查找 C++ 包含文件名
- 通过构造函数创建一些值并尝试添加到文档中使用 rapidjson 不起作用
- 关于类的 Python 文档 - 对C++的引用不正确
- C++/autoconf 等效于文档库要求.txt的要求是什么?
- mbed:使用 USB 文档库编译会导致错误
- C++ VISUAL STUDIO:GLFWwindow没有初始化,即使它是在文档中编写的并且以前工作过
- 使用 yaml-cpp 更新 YAML 文档的节点和值
- 在加载 MSHTML 文档之前从 MSHTML 文档中删除无效的 URL
- 如何在C++中表示JSON文档的递归对象结构?
- 如何查找 Redshift Maya API 文档?
- 如何使用值模板编写文档测试用例?
- 如何使用 Gradle DSL(领域特定语言)上的文档?
- ncurses 找不到任何关于cchar_t的文档
- 提取狮身人面像文档中的C++代码片段
- 关于 API 文档和设备操作 在助手-sdk-cpp 上
- 如何搜索提升文档?
- 使用 mongo c++ 驱动程序查询嵌套的 BSON 文档
- 重载返回的类(例如 xmlpp 中的 DomParser's 文档)