- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在我的 Qt 项目中,我有一个如下所示的类。我收到以下警告(已理解),并添加了一个虚拟 dtor。
dbmappingcomponentaware.h:25: 警告:CDbMappingComponentAware 具有虚函数但非虚析构函数
现在我明白了
警告:“CDbMappingComponentAware”的隐式复制赋值运算符的定义已弃用,因为它具有用户声明的析构函数
该类是普通类,我没有声明任何运算符。我将如何解决该冲突?
截至How to disable implicitly-defined copy constructor generation when there is user defined destructor看起来我必须接受“已弃用”警告,但我不确定。
代码片段:
//! Allows subcomponents to gain access to model component
class CDbMappingComponentAware {
public:
//! Destructor (added for 1st warning)
// virtual ~CDbMappingComponentAware() {}
//! Set the corresponding component
virtual void setMappingComponent(CDbMappingComponent *component);
...
...
-- 根据评论编辑--
阅读 https://en.cppreference.com/w/cpp/language/copy_assignment它说,
The generation of the implicitly-defined copy assignment operator is deprecated(since C++11) if T has a user-declared destructor or user-declared copy constructor.
但这是为什么呢?我的意思是,为什么 dtor 会影响复制运算符(operator)?
最佳答案
As of How to disable implicitly-defined copy constructor generation when there is user defined destructor it looks like I have to accept the "deprecated" warning, but I am not sure.
您不必接受“已弃用”警告。您在这里有 3 个选项,实现 运算符,显式默认 运算符或删除 运算符。
首先,触发此警告是因为您实际上在某处使用了复制赋值运算符
。甚至可能不是故意的(参见下面示例中的 //unfortunate mistake
)。除了使用运算符的警告之外,您实际上应该得到一条注释,例如:
note: in implicit copy assignment operator for 'CDbMappingComponentAware' first required here
考虑以下示例 ( running version ):
class foo {
public:
virtual ~foo() {}
// options
// implement
//foo& operator=(foo const&) {return *this;}
// default
//foo& operator=(foo const&) = default;
// delete
//foo& operator=(foo const&) = delete;
};
class bar : public foo {
public:
~bar() override {};
};
// stupid mistake... should be defined
// void fn(bar const&)
void fn(bar) {}
int main(int, char*[]) {
foo* f1 = new bar;
foo* f2 = new bar;
// triggers warning
*f1 = *f2;
// unfortunate mistake
bar b;
// triggers warning twice since bar inherits from foo
fn(b);
return 0;
}
在这种情况下,您确实在使用复制赋值运算符
,您应该实现它,或者默认它(如果确实如此) 纯 Vanilla 。请参阅下文为什么您最终不应该默认它。如果您根本不想复制实例,请删除运算符/构造函数。
顺便说一句,复制构造函数也是一样的,不仅仅是赋值运算符。复制构造函数在§15.8.1/6中描述,复制赋值运算符在§15.8.2/2中描述n4727 .
但是:
But would that not mean I cannot copy a object if I define a virtual dtor (unless I explicitly write a copy assignment operator).
不,你仍然可以使用生成的复制构造函数/赋值,只要它是一个警告。弃用意味着它将(可能)在未来成为一个错误(对于 C++,可能在大约 40 年或更长时间后,如果有的话)。因此,如果您不希望您的代码在编译器不再支持它时将此警告作为错误发出,您应该立即修复它。
But why is that? I mean, why is the dtor affecting the copy operator?
这里假设的答案:
我能想到的一个目的是防止一些错误。考虑示例(取自 Why doesn’t my constructor work right? ):
class Handle {
private:
string name;
X* p;
public:
Handle(string n)
:name(n), p(0) { /* acquire X called "name" and let p point to it */ }
~Handle() { delete p; /* release X called "name" */ }
};
void f(const string& hh)
{
Handle h1(hh);
Handle h2 = h1; // leads to disaster!
}
Here, the default copy gives us h2.name==h1.name and h2.p==h1.p. This leads to disaster: when we exit f() the destructors for h1 and h2 are invoked and the object pointed to by h1.p and h2.p is deleted twice.
为防止双重删除,您必须明确且不依赖于生成的/默认的复制构造函数/赋值。
Are you saying the warning is there to enforce the rule of three?
在这种特殊情况下:是,我会这么说。
As I do not deal with resources the rule of three does not make really sense here.
这将要求编译器考虑成员。为这样一个不成熟的警告付出了很多努力。
恕我直言,我不相信这会成为 C++ 中的错误。依赖于自动生成的构造函数/赋值,有很多代码可以使用。犯这个错误会破坏(字面上)数以千计的项目。 -> 不会发生...
关于c++ - 冲突的 CLANG `virtual dtor` 和 `deprecated copy operator` 警告,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51971439/
如何将 jQuery 代码转换为 React JS? 我有一个带有文本“复制”的按钮。当我单击它时,应将其文本更改为“已复制”并复制到剪贴板。复制后,几秒钟后我希望文本返回到“复制”。我相信以下功能将
在任何情况下我都想使用 NumPy 的 np.copy() 而不是 Python 的 copy.copy() 方法?据我所知,两者都创建浅拷贝,但 NumPy 仅限于数组。 NumPy 是否有任何性能
%python -m timeit -s "import copy" "x = (1, 2, 3)" "copy.deepcopy(x)" 100000 loops, best of 3: 10.1
我想制作一个列表的副本(字面意思是一个单独的克隆,与原始列表没有任何共享)。我使用了 copy.copy() 并创建了 2 个单独的列表,但为什么每个副本的元素似乎仍然共享? 这很难解释,请查看以下输
我不明白使用通配符时 COPY 命令的行为。 我在 C:\Source 中有一个文本文件叫 mpt*.asm我想把它复制到 C:\Dest .这是批处理脚本所需要的,我不能确定 mpt*.asm 的确
相关但不等同于:Golang: How to copy Context object without deriving 是否可以推导出 context.WithTimeout来自 context.Ba
您可以实现 Copy 特性来为类型提供复制语义而不是 move 语义。仅当其所有组成元素(产品类型的每个因素,或总和类型的每个变体的每个因素)也都是复制时,才能执行此操作。 这还允许您制作相当大的类型
我有一段代码,我需要确定编码值的类型,但我不知道它是字符串、无符号整数还是字符串的矢量。我想做以下几件事:。然而,来自弯曲板条箱的值不能实现复制,它在调用Decode_Bencode_Object之后
我需要复制一些对象,我读到 copy.copy 模块可以在 Python 上执行此操作。问题是,这些对象有一些属性是长数组。 那么这个方法效率高吗?由于性能在我所做的这项工作中很重要。 有更好的方法吗
我尝试高效地制作 lua 表的副本。我编写了以下运行良好的函数 copyTable()(见下文)。但我想我可以使用函数的“按值传递”机制获得更高效的东西。我做了一些测试来探索这个机制: functio
使用 pry 插件:pry-clipboard 当我输入“copy-history”来复制我历史的最后一行时,它实际上是在复制“copy-history”并粘贴“copy-history”。 我是不是
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 11 个月前关闭。 Improve this
我不了解Kotlin中通过访问器处理字段和复制方法之间的区别。就像这样: 访问者示例: class Person(val name: String, var age: Int
如何从节点复制一些属性。例如。我只想从节点“Extn”复制“Srno”,“RollNo”,“right”。
我有以下两个 XSL 转换,我希望将它们链接到一个 XSL 文件中。 第一次转换: 第二个转换(使用第一个转换的输出作为输入): 我的目标是从 WSDL
我是 Vertica DB 的新手,之前使用过 Mysql。我想在 vertica 表中插入唯一记录,但 vertica 在插入时不支持唯一约束。我通过 COPY 查询在表中插入记录。所以我无法在插入
std::copy 与执行策略参数之间是否存在正式关系?无论是在实践中还是在标准中。 例如,会不会只是这样, namespace std{ template It copy(std::
我用 root 运行了以下命令来备份同一主机上的文件夹:cp -r master 主备 size of master : 76GB size of master-backup : 71GB 知道为什么
我遇到过一段代码,乍一看似乎毫无意义。但我意识到这可能会产生一些我不知道的未知含义,因为 Python 不是我最熟悉的语言。 import copy node = copy.copy(node) 阅读
我正在设计一个基类,我希望它为 copy.copy 定义基本行为。此行为包括在控制台中打印警告,然后复制实例,就好像它没有 __copy__ 一样。属性。 当定义一个空白时Foo类并复制它的一个实例,
我是一名优秀的程序员,十分优秀!